PAT说反话

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

#include<iostream>
#include<string.h>
using namespace std;

int main() {
    char a[90], b[90][90];
    int h=0,r=0;
    int c[90] = { 0 };

    cin.getline(a, 81);
    
    int len=strlen(a);//为了避免无字符类型和有字符类型比较,把strlen改成了int

    for (int i = 0; i <len ; i++) {//我们将每个单词存到数组的一行中
        if (a[i] != ' ') {
            b[r][h++] = a[i];
        }

        else {
            b[r][h] = '\0';
            c[r] = h;
            r++;
            h = 0;
        }//有空格,把单词大小赋值给c,指向下一行的开始。

    }

    c[r] = h;//最后一个单词的大小复制给数组c

    for (int i = r; i >=0; i--) {
        int q = 0;
        while (q<c[i]) {
            cout << b[i][q++];
        }//从后向前逐行输出

        if (i != 0)
            cout << " ";
    }//除了输入第一个单词的结尾,其他全部加上空格
}

猜你喜欢

转载自blog.csdn.net/qq_42082542/article/details/83793676