写一个函数,将一个字符串中的单词反转过来,单词的定义是:完全由字母组成且由空格分开的字符串。例如下面的字符串:“a hello1 abc good!”,其中“a”和“abc”是单词,而“hello1”和“good!”不是单词(原因是这两个字符串中包含非字母的字符1和!)。反转过来的结果就是“a hello1 cba good!”
要求:尽可能使用C/C++。禁止使用split、strlen等函数
char str[100] = "a hello1 abc good!"; int j = 0; int i = 0; for(; str[i]!=' ';i++){ if((str[i]>='a'&&str[i]<='z')||(str[i]>='A'&&str[i]<='Z')||str[i]==' '){//是字母或空格 if(str[i]==' '){ if(j!= -1){ for(int k = j;k<(i-1+j)/2;k++){ //反转单词 char t = str[k]; str[k] = str[i-1-(k-j)]; str[i-1-(k-j)] = t; } } j = i+1; } } else{ j = -1; //代表当前单词中包含非字母元素 } } //处理最后一个单词 if(j!= -1){ for(int k = j;k<(i-1+j)/2;k++){ //反转单词 char t = str[k]; str[k] = str[i-1-(k-j)]; str[i-1-(k-j)] = t; } }