一:问题:
输入一串字符串倒序输出
例:输入abcdefg 输出gfedcba
二:思路:
(1)先输入一串字符串,然后利用for语句倒序输出即可;
三:实现过程:
(1)先输入一串长度为n的字符串:(若不可自定义长度的,可以为字符串数组初始大一点的值即可!!!)
char arr[100];
printf("请输入一串字符串:");
scanf_s("%s", arr, 100);//其他编译器不一定要加上这“100”的限定
注:由于VS编译器在输入字符串时,要在后面限定最大长度,故要加一个范围
(2)接下来就要处理计算一下该字符串的元素长度(不包括'\0')
int i = 0;//i相当于计数器
while (i >= 0)
{
if (arr[i] != '\0')//如果arr[i]不等于0,便让i++
{
i++;//如果输入时i==0,那输出时便是i==1,永远会比原先多1,这就达到我们的目标了;
}
else
{
break;
}
}
(3)接下来最后的i的最终值作为初始值,用for循环来倒序输出:
printf("倒序后:");
for (int j = i; j >= 0; j--)
{
printf("%c", arr[j]);
}
四,代码与运行图:
#include<stdio.h>
int main()
{
char arr[100];
printf("请输入一串字符串:");
scanf_s("%s", arr, 100);
int i = 0;
while (i >= 0)
{
if (arr[i] != '\0')
{
i++;
}
else
{
break;
}
}
printf("字符串元素个数:%d\n", i + 1);//包括了'\0'这个符号
printf("倒序后:");
for (int j = i; j >= 0; j--)
{
printf("%c", arr[j]);
}
return 0;
}