【PTA-乙级】1009-说反话 (三种解法)

2023-10-17 22:30

本文主要是介绍【PTA-乙级】1009-说反话 (三种解法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言: 更新: 之前的前言是我说我写的第一种解法测试点3过不去,经过若干天后我重新看这个题。仍然觉得没问题 然后把字符数组的大小改为82就过了测试点3。 鬼知道什么情况。应该是输入的测试用例不规范吧

题目:

解法1  char型数组与string数组赋值解法:

#include<iostream>
#include<cstring>
using namespace std;
int main()
{char arr[82] = {0};int i = 0;while ((arr[i] = getchar()) != '\n')i++;// 用来存放每一个单词string brr[40];char* p = arr;int a = 0;// 调整字符串for (int j = 0; j < 81; j++){if (arr[j] == ' ' || arr[j] == '\n')arr[j] = '\0';}// 正序存放单词while (*p != '\0'){brr[a] = p;while (*p != '\0')p++;p++;a++;}//  逆序打印单词for (int i = a - 1; i >= 0; i--){cout << brr[i];if (i == 0)break;cout << " ";}
}

注:1.  如果把这个代码整体调试一遍   会让你对字符数组,string类型对象,缓冲区等有更深的理解 (对于我来说) 建议调试一遍

2.  如果把一个字符数组里面的内容存放在一个string类型的对象中   空格不会作为终止符  只有'\0'才会终止  如下图  这也是为什么存放单词之前要对字符串调整 让每个单词成功存入string数组中

解法2  :string数组解法(最简单的解法)

#include<iostream>
using namespace std;
#include<cstring>
int main()
{//string c;//cin >> c;    //输入时 空格 \n都会称为终止输入的标志//Hello' 'World' 'Here' 'I' 'Come'\n'string arr[80];int a = 0;char c;while (1){cin >> arr[a];a++;c = getchar();if (c == '\n')break;}for (int i = a - 1; i >= 0; i--){cout << arr[i];if (i == 0)break;cout << " ";}return 0;
}

注:  在输入string类型对象时   ' '  和  ‘\n' 都会作为输入终止的标志 所以在循环输入时  完全可以放心可以把正确的单词输入进string型数组中  最后把'\n'作为循环终止的标志  退出循环即可

解法3 :char型二维数组解法

#include<iostream>
using namespace std;
#include<cstring>// 1009说反话 解法3:
int main()
{char arr[81][81];char c;int length = 0;int i = 0;//Hello ' ' World ' ' Here ' ' I ' ' Come '\n'while ((c = getchar()) != '\n'){if (c != ' '){arr[length][i] = c;i++;}else{arr[length][i] = '\0';length++;i = 0;}}arr[length][i] = '\0';for (int i = length; i >= 0; i--){cout << arr[i];if (i == 0)break;cout << " ";}return 0;
}

这个解法是  创建char型二维数组 把每个单词放置一行中  由于打印时会因'\0'终止 所以逆序打印出结果即可  

总结:  如果可以把三种解法都调试一遍 会对数据的存入与读取有更深的理解;(别忘了解法1的测试点3过不去)

这篇关于【PTA-乙级】1009-说反话 (三种解法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/228374

相关文章

如何将Python彻底卸载的三种方法

《如何将Python彻底卸载的三种方法》通常我们在一些软件的使用上有碰壁,第一反应就是卸载重装,所以有小伙伴就问我Python怎么卸载才能彻底卸载干净,今天这篇文章,小编就来教大家如何彻底卸载Pyth... 目录软件卸载①方法:②方法:③方法:清理相关文件夹软件卸载①方法:首先,在安装python时,下

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

C语言实现两个变量值交换的三种方式

《C语言实现两个变量值交换的三种方式》两个变量值的交换是编程中最常见的问题之一,以下将介绍三种变量的交换方式,其中第一种方式是最常用也是最实用的,后两种方式一般只在特殊限制下使用,需要的朋友可以参考下... 目录1.使用临时变量(推荐)2.相加和相减的方式(值较大时可能丢失数据)3.按位异或运算1.使用临时

Java终止正在运行的线程的三种方法

《Java终止正在运行的线程的三种方法》停止一个线程意味着在任务处理完任务之前停掉正在做的操作,也就是放弃当前的操作,停止一个线程可以用Thread.stop()方法,但最好不要用它,本文给大家介绍了... 目录前言1. 停止不了的线程2. 判断线程是否停止状态3. 能停止的线程–异常法4. 在沉睡中停止5

Linux配置IP地址的三种实现方式

《Linux配置IP地址的三种实现方式》:本文主要介绍Linux配置IP地址的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录环境RedHat9第一种安装 直接配置网卡文件第二种方式 nmcli(Networkmanager command-line

Linux下修改hostname的三种实现方式

《Linux下修改hostname的三种实现方式》:本文主要介绍Linux下修改hostname的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下修改ho编程stname三种方式方法1:修改配置文件方法2:hFvEWEostnamectl命

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

Spring IOC的三种实现方式详解

《SpringIOC的三种实现方式详解》:本文主要介绍SpringIOC的三种实现方式,在Spring框架中,IOC通过依赖注入来实现,而依赖注入主要有三种实现方式,构造器注入、Setter注入... 目录1. 构造器注入(Cons编程tructor Injection)2. Setter注入(Setter

linux报错INFO:task xxxxxx:634 blocked for more than 120 seconds.三种解决方式

《linux报错INFO:taskxxxxxx:634blockedformorethan120seconds.三种解决方式》文章描述了一个Linux最小系统运行时出现的“hung_ta... 目录1.问题描述2.解决办法2.1 缩小文件系统缓存大小2.2 修改系统IO调度策略2.3 取消120秒时间限制3