文章目录
- 前言
- 一、题目描述
- 二、题目分析
- 三、解题
- 1.解题方法一--- for循环来将字符的下标数值进行对每一个字符进行交换 ---
- 程序运行代码
- 2.解题方法二------ 指针 ------
- 程序运行代码(1)
- 程序运行代码优化
- 总结
前言
本系列为C语言菜鸟100道基础经典例题详解刷题系列。点滴成长,一起逆袭。
一、题目描述
实例35—字符串反转(字符串数组逆序输出),如将字符串 “www.runoob.com” 反转为 “moc.boonur.www”。
二、题目分析
对c语言的字符串进行反转,将abcdef反转为fedcba的办法有很多,而我所使用的方法是for循环来将字符的下标数值进行对每一个字符进行交换。
1.首先我们需要算出字符的长度,strlen是一个很好的办法,为什么不用sizeof的原因也很简单,因为sizeof算出来的长度是包括了’/0’的。
(1). int len = sizeof(arr)/sizeof(int); //这是算长度 但是会将最后一个\0算进去
(2). int len = strlen(arr); //strlen是计算有效的内存长度
(3).也就是(2)的详细代码
for(i=0;str[i]!='\0';i++){
len++;
}
2.计算出字符所拥有的长度之后,从首开始进行交换,所以要将计算出来的长度len除于2,否则在前面交换完毕之后,会在后面再一次交换,导致数值不变。
但是在交换的时候,我们要注意一个问题,那就是在交换的时候要搞出一个第三方数值,原因是因为一旦将9赋值于1的时候,9的位置却得不到1的值,就会导致转换结果失败,变成对称的形式。
三、解题
1.解题方法一— for循环来将字符的下标数值进行对每一个字符进行交换 —
程序运行代码
#include<stdio.h>
#include<string.h>
int main()
{
char str[40],temp;
gets(str);
int len,i;
len=strlen(str);//strlen是计算有效的内存长度
for(i=0;i<len/2;i++){//用/2 来进行反转
temp=str[i];
str[i]=str[len-1-i];
str[len-1-i]=temp;
}
puts(str);
// for(i=0;i<len;i++){
// printf("%c",str[i]);
// }
return 0;
}
2.解题方法二------ 指针 ------
程序运行代码(1)
#include<stdio.h>
#include<string.h>
int main()
{
char str[40],temp;
gets(str);
char *p=str;
int len,i;
// len=strlen(str);
while(*p!='\0'){
len++;
p++;
}
for(i=0;i<len/2;i++){
temp=*(str+i);
*(str+i)=*(str+len-1-i);
*(str+len-1-i)=temp;
}
puts(str);
return 0;
}
程序运行代码优化
#include<stdio.h>
#include<string.h>
void reverstre(char* str)
{
// 获取字符串长度
int len = 0;
char* p = str;
while (*p != 0)
{
len++;
p++;
}
// 交换 ...
int i = 0;
char temp;
while (i < len / 2)
{
temp = *(str + i);
*(str + i) = *(str + len - 1 - i);
*(str + len - 1 - i) = temp;
i++;
}
}
int main()
{
char str[] = "www.runoob.com";
reverstre(str); // 反转字符串
puts(str);
return 0;
}