【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过不去)

  • 6
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集 PTA-数据结构与算法题目集

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值