PAT B1009

原创 2017年08月13日 10:02:03

题目链接

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

输入格式:测试输入包含一个测试用例,在一行内给出总长度不超过80的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用1个空格分开,输入保证句子末尾没有多余的空格。

输出格式:每个测试用例的输出占一行,输出倒序后的句子。

输入样例
Hello World Here I Come

输出样例
Come I Here World Hello


解法一

#include <iostream>
#include <string>
using namespace std;
int main()
{
    string str[10];
    getline(cin, str[0]);
    decltype(str[0].size()) j = 1;
    for (decltype(str[0].size()) i = 0; i < str[0].size(); i++) {
        if (!isspace(str[0][i]))
            str[j] += str[0][i];
        else j++;
    }
    for (decltype(str[j].size()) i = j; i > 0; i--) {
        cout << str[i];
        if (i != 1)
            cout <<" ";
    }
    return 0;
}

解法二

#include<string>
#include<iostream>
#include<vector>
using namespace std;
int main() {
  string s,r;
  vector<string> v;
  getline(cin, s);
  for (decltype(s.size()) index = 0; index != s.size(); index++) {
    if(!isspace(s[index]) ){
      r += s[index];
    }
    else {
      v.push_back(r);
      r.clear();
    }
  }
  v.push_back(r);
  for (auto rit = v.rbegin();rit !=v.rend(); rit++)
  {
    cout << *rit;
    if (rit != v.rend() - 1) cout << " ";
  }
  return 0;
}

解法三

#include <iostream>
#include <string>
#include<sstream>
#include<vector>
using namespace std;
int main()
{
    string line,s;
    vector<string> v;
    bool firstword = true;
    getline(cin, line);
    istringstream stream(line);
    while(stream>>s)
    v.push_back(s);
    for (auto rit = v.rbegin(); rit != v.rend(); rit++)
    {
        if (firstword)
            firstword = false;
        else 
            cout << " ";
        cout << *rit;
    }
}

PAT-1009B 说反话 (20)

时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定一句英语,要求你...

PAT 1009. 说反话 (20)

  • 2014年09月05日 17:28
  • 456B
  • 下载

PAT程序设计考题——甲级1009(计算两个多项式相乘的积)

题目原文链接:点击打开链接 翻译题目要求: 程序输入为两行:均为一个多项式,按格式K N1 An1 N2 An2......Nk Ank,K代表的是多项式的非零项数,范围闭区间是[1,10],N1...

PAT乙级 1009 说反话

题目地址:https://www.patest.cn/contests/pat-b-practise/1009题目描述:给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。输入格式:测试输入包...

pat1009,字符串的输入处理

地址:http://pat.zju.edu.cn/contests/pat-b-practise/1009 本题中遇到的问题: scanf("%s%c", buf, c); 忘记&,运行...
  • Staibin
  • Staibin
  • 2014年02月24日 09:09
  • 425

浙大PAT考试1009~1012(1010是个神题。。)

哎,pat1010居然用java写的,不仅用java写的,还加了二分,,,唉,智商捉急啊,主要是pat有的范围也不给清楚。给人造成遐想的空间。。 还是按顺序介绍。。 题目地址:http:/...
  • opm777
  • opm777
  • 2014年06月13日 01:22
  • 1621

浙大 PAT Advanced level 1009. Product of Polynomials

This time, you are supposed to find A*B where A and B are two polynomials. Input Specification: Ea...

PAT (Basic Level)1009. 说反话

http://www.patest.cn/contests/pat-b-practise/1009 描述: 给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。 输入格式:测试输入包含一...

PAT 1009(甲级) Product of Polynomials

1.简单题直接开辟数组在对应的下标作为指数的情况下,保存每一项的系数即可。注意数组开的足够大,至少是2000; 2.我用的链表,有一处坑点是注意系数可能取负值。 #includeiostream>...

Pat(Advanced Level)Practice--1009(Product of Polynomials)

Pat1009代码 题目描述:This time, you are supposed to find A*B where A and B are two polynomials. In...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:PAT B1009
举报原因:
原因补充:

(最多只允许输入30个字)