zoukankan      html  css  js  c++  java
  • B1009 说反话

    /*
    题目描述
    给定一个英语,要求编写程序,将句中所有单词按颠倒顺序输出
    
    输入格式
    测试输入包含一个测试用例,在一行内给出总长度不超过80的字符串。字符串由若干单
    词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用1个
    空格分开,输入保证句子末尾没有多余的空格。
    
    输入格式
    每个测试用例的输出展一行,出倒叙后的句子。
    
    样例输入
    Hello World Here I Come
    
    样例输出
    Come I Here World Hello
    **************************************************
    思路
    使用gets函数读入一整行,从左至右枚举每一个字符,以空格为为分隔符对单词进行划分
    并按照顺序存放到二维字符数组中,最后按单词输入顺序的逆序来输入所有单词
    
    注意点
    1、最后一个单词之后输入空格会导致“格式错误”。
    2、由于PAT是单点测试,因此产生了下面这种更简洁的方法,即使用EOF来判断是否已经输入完毕
    */
    #include <iostream>
    #include <stdio.h>
    #include <string.h>
    using namespace std;
    int main(){
        char str[90];
        gets(str);
        int len =strlen(str),r=0,h=0;  //r为行,h为列
        char ans[90][90];    //ans[0]~ans[r] 存放单词
        for(int i=0;i<len;i++)
        {
            if(str[i]!=' '){    //如果不是空格,则存放ans[r][h],并令h++
                ans[r][h++]=str[i];
            }
            else {    //如果是空格,说明一个单词结束,行r增加1,列恢复至0
                ans[r][h]='';      //末尾是结束符
                r++;
                h=0;
            }
        }
        for(int i=r;i>=0;i--)   //倒着输出单词即可
        {
            printf("%s",ans[i]);
            if(i>0) printf(" ");
        }
    return 0;
    }
    
    /*
    #include <stdio.h>
    
    int main()
    {
        char str[80][80];             //二维数组每一行存放一个单词
        char dsr[80];                 //存放输入的字符串
        int i, j = 0, k = 0;
        for(i = 0; i < 80; i++) {
            scanf("%c", &dsr[i]);
            if(dsr[i] == '
    ') {      //当输入回车时结束
                break;
            }
        }
        dsr[i] = '';                //让字符串中最后一个字符(回车符)等于''
        for(i = 0; i < 80; i++) {
            if(dsr[i] == '') {
                str[j][k] = '';
                break;
            }
            str[j][k]  = dsr[i];      //将单词存到第 j 行
            k++;
            if(dsr[i] == ' ') {
                str[j][k-1] = '';   //将空格换成''
                j++;
                k = 0;
            }
        }
        int t = j;                    //共有 t 个单词
    
        for(j = t ; j >= 0; j--) {
            printf("%s", str[j]);
            if(j != 0) {
                printf(" ");
            }
        }
    
        return 0;
    }
    */
  • 相关阅读:
    hdu 3037 Saving Beans fzu 2020 组合 hit 2813 Garden visiting hrbeu 组合数 fzu 1564 Combination
    PKU 2429 GCD & LCM Inverse
    Discrete Logging hunnu10590 pku2417 fzu 1352 hit 1928 zoj 1898
    HDUBased Game Theory
    Perfect Pth Powers zoj 2124 pku1730 hunnu10585
    More Divisors zoj 2562
    服务器的安全配置技巧总结
    sql server中datetime字段只取年月日如20060421,默认值如何设置?getdate()得到的是包含时分秒的时间
    获取当前打印机的名称、驱动程序、打印端口信息
    如何使用Delphi设计强大的服务器程序
  • 原文地址:https://www.cnblogs.com/z-712/p/7324017.html
Copyright © 2011-2022 走看看