c语言

写一个函数,将一个字符串中的单词反转过来,单词的定义是:完全由字母组成且由空格分开的字符串。例如下面的字符串:“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]!='\0';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;
        }
    }

 

posted @ 2018-10-15 11:03  刚刚888  阅读(523)  评论(0编辑  收藏  举报