PAT-B 1009. 说反话 (20)

传送门

https://pintia.cn/problem-sets/994805260223102976/problems/994805314941992960

题目

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:测试输入包含一个测试用例,在一行内给出总长度不超过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]);

    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,275评论 0 4
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,823评论 18 399
  • 【作者】王佳诚 【派别】文魁派 【导师】王玉印老师 【分舵】第二分舵 思维分舵 【舵主】吕柯姣 【导图解说】 扫描...
    王佳诚阅读 615评论 5 0
  • 是的,这些天,消沉无比,几乎,我觉得自己已经快要放弃自己。但只是快要,不会真的放弃。这些天,感觉到自己的挣扎,奋力...
    冠世墨玉yanzi阅读 284评论 2 2
  • 董沛沛 洛阳 焦点网络五期 坚持原创分享第四十九天 坚持分享七七四十九天,为自己点赞。 今天学习的内容...
    缘源流长阅读 225评论 0 0