遇到一个题目:编写程序颠倒句子中单词的顺序。
例:Enter a sentence: you are beautiful.
Reversal of sentence: buautiful are you.
这是我第一次码出的代码
#include <stdio.h>
int main()
{
#pragma warning(disable : 4996)
char ch[100];
int i=1,a=0,b=0;
printf("Enter a sentence: ");
ch[0] = ' ';
do {
ch[i] = getchar();
i++;
} while (ch[i - 1] != '.' && ch[i - 1] != '?' && ch[i - 1] != '!');
i--;
printf("Reversal of sentence: ");
for (a = i-1; a!=-1; a--) {
if (ch[a] == ' ') {
b = a;
while (ch[a + 1]!= ' '&& a+1!=i ) {
printf("%c", ch[a + 1]);
a++;
}
if(b!=0)printf(" ");
a = b;
a--;
}
}
printf("%c", ch[i]);
return 0;
}
结果输出一堆乱码,然后我将第十五行的for (a = i-1; a!=-1; a--) 改成for (a = i-1; a>=0; a--) ,程序就能正确运行了。
但接下来我将for (a = i-1; a>=0; a--)改成for (a = i-1; a>=-1; a--),程序仍能正常运行,甚至改成a>=-2都行,可ch[-1]和ch[-2]显然不存在啊。
所以我想问问为什么for (a = i-1; a!=-1; a--)不行,以及for (a = i-1; a>=-1; a--)乃至a>=-2能行
因为你这个a并不是每次都是减去1。所以,在递减过程中,有可能a的值在循环时会跳过-1这个值,导致a!=-1一直成立。比如a=-3时,a!=-1是成立的,但a>=-1是不成立的,就能退出循环了
a从i-1开始一直减到-1,a>=-1都是成立的,但是a!=-1是不成立的,所以循环就没进入