PAT 1164 Good in C


这一题思路上没有什么复杂的,按题意模拟,即可

关建在于格式,题目上说不同的单词中间有其他非A到Z的字符隔开,但可能只有一个单词,那么结尾就可能没有其他字符,可能在两个单词之间其他字符可能有多个,甚至这里的其他字符包括空格!!!

因此在输入一串单词的时候我们应该用getchar来吞掉输入A到Z对应的的矩形输入后的回车,然后再用getline(cin,s)来读取字符串(为啥用getline因为有空格)

完整代码如下:

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include<iostream>
#include <unordered_map>
#include <vector> 
#include <cstring>
#include <cstdio>
#include <string.h>
#include <string>
using namespace std;
unordered_map<char, vector<vector<char>> > mp;
int main()
{
	for (int i = 0; i < 26; i++)
	{
		vector<vector<char>> t(7);
		for (int j = 0; j < 7; j++)
		{
			for (int k = 0; k < 5; k++)
			{
				char x;
				cin >> x;
				t[j].push_back(x);
			}
		}
		mp[char('A' + i)] = t;
	}
	getchar();
	string s;
	getline(cin, s);
	vector<string> x;
	int last = -1;
	string tt="";
	for (int i = 0; i < s.size(); i++)
	{
		if (s[i] >= 'A' && s[i] <= 'Z')
		{
			//符合条件
			tt += s[i];
		}
		else
		{
			if(tt.size()!=0)
			x.push_back(tt);
			tt = "";
		}
	}
	if (tt.size() != 0)
	{
		x.push_back(tt);
	 }
	//这样就把每一个单词给分割了
	
	for (int p = 0; p < x.size(); p++)
	{
		for (int i = 0; i < 7; i++)
		{
			string temp = x[p];
			for (int j = 0; j < temp.size(); j++)
			{
				vector<vector<char>> ans = mp[temp[j]];
				for (int k = 0; k < ans[i].size(); k++)
				{
					cout << ans[i][k];
				}
				if(j!=temp.size()-1)
				cout << " ";
			}
			
			cout << endl;
		}
		if (p != x.size() - 1)
		{
			cout << endl;
		}
	}
	


	return 0;
}

注意PAT的输出末尾不能有空格

相关推荐
小杍随笔几秒前
【Rust 语言编程知识与应用:同步机制详解】
开发语言·算法·rust
GawynKing17 分钟前
Java文件传输利器:MultipartFile介绍
java·开发语言
Java.熵减码农18 分钟前
经典20道Java面试题系列(一)
java·开发语言
小龙报34 分钟前
【数据结构与算法】栈和队列的综合应用:1.用栈实现队列 2.用队列实现栈 3.设计循环队列
c语言·数据结构·数据库·c++·redis·算法·缓存
MyBFuture36 分钟前
Halcon 图像处理技巧:抠图与形态学操作指南
开发语言·halcon
Aurorar0rua44 分钟前
CS50 x 2024 Notes C - 01
c语言·学习方法
qq_416018721 小时前
移动平台C++开发指南
开发语言·c++·算法
自动化智库1 小时前
西门子S7-1200PLC与V90PN伺服基于FB284模块的定位控制应用
开发语言·科技
3GPP仿真实验室1 小时前
【MATLAB源码】CSI-RS:信道估计仿真与评估平台
开发语言·matlab
AI-小柒1 小时前
DataEyes 聚合平台 + Claude Code Max 编程实战
android·开发语言·人工智能·windows·python·macos·adb