美文网首页
PAT-B 1009. 说反话 (20)

PAT-B 1009. 说反话 (20)

作者: Rush的博客 | 来源:发表于2016-09-18 15:56 被阅读2200次

    传送门

    https://www.patest.cn/contests/pat-b-practise/1009

    题目

    给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
    输入格式:测试输入包含一个测试用例,在一行内给出总长度不超过80的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用1个空格分开,输入保证句子末尾没有多余的空格。
    输出格式:每个测试用例的输出占一行,输出倒序后的句子。
    输入样例:
    Hello World Here I Come
    输出样例:
    Come I Here World Hello

    分析

    C++实现方法:
    这里我参考了别人的代码,运用了一个小方法。
    1.先从尾部遍历数组,找到空格的时候就将空格后面的输出;
    2.输出后,将空格替换为\0,这也是字符串终止的标志;
    3.然后向前遍历,找到空格是继续将空格后面的内容输出,因为将后面的空格替换为\0了,所以输出完这个单词就会终止,以此类推直到遍历到数组头部终止,即可。

    Java实现方法:
    这道题用Java做简直是轻而易举,因为Java为字符串提供了split函数,可以通过指定字符串来分割字符串并放入新的字符串数组里,处理完字符串后,只需要倒序输出字符串数组,并加入空格即可。

    源代码

    //C/C++实现
    #include <stdio.h>
    #include <iostream>
    #include <string.h>
    
    using namespace std;
    
    int main(){
        char c[82];
        gets(c+1);
        c[0] = ' ';
        for(int i=strlen(c);i>=0;i--){
            if(c[i] == ' '){
                printf("%s", c+i+1);
                c[i] = '\0';
                if(i == 0){
                    printf("%c", '\n');
                }
                else{
                    printf("%c", ' ');
                }
            }
            else{
                continue;
            }
        }
        return 0;
    }
    
    //Java实现
    import java.util.Scanner;
    public class Main {
    
        public static void main(String[] args) {
            Scanner scanner = new Scanner(System.in);
            String s = scanner.nextLine();
            String array[] = s.split(" ");
            int i=array.length-1;
            for(;i>0;i--){
                System.out.print(array[i]+" ");
            }
            System.out.println(array[i]);
    
        }
    }
    

    相关文章

      网友评论

          本文标题:PAT-B 1009. 说反话 (20)

          本文链接:https://www.haomeiwen.com/subject/ioqgettx.html