APTX Blog

A Moe Blog Set Up By APTX

#洛谷#C/C++P4470 [BJWC2018]售票

题目描述

C 市火车站最近出现了一种新式自动售票机。买票时,乘客要先在售票机上输入终点名称。一共有N 处:目的地,随着乘客按顺序输入终点名称的每个字母,候选终点站数目会逐渐减少。

在自动售票机屏幕上,有一个4 行8 列的键盘,如下图所示。

《#洛谷#C/C++P4470 [BJWC2018]售票》

在乘客每输入一个字母后,键盘上只有有效字符是可选的(取决于还有哪些候选终点站),其余的字母会被字符’*’ 取代。

告诉你N 处目的地的名称,以及乘客已经输入的若干字符,请你输出键盘目前的状态。

输入输出格式

输入格式:

第一行为一个整数N (1≤N ≤50)。接下来N 行,每行一个由大写英文字母组成的长度不超过100 的字符串,表示一处目的地。最后一行,一个长度不超过100 的字符串,表示按顺序输入的若干字符。

输出格式:

输出4 行,每行一个长度为8 的字符串,表示键盘状态。

输入样例#1:

4
ZAGREB
SISAK
ZADAR
ZABOK
ZA

输出样例#1:

****B*D*
*G******
********
********
********

说明

【样例解释】

输入ZA 以后,下一个字符可能是G(终点站有可能是ZAGREB),或D(终点站有可能是ZADAR ),或B(终点站有可能是ZABOK )。

本人提供的题解

简单的模拟,注意,千万别开ios的那个同步,全WA

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstdlib>
#include<string>
#include<cstring>
using namespace std;

const int maxn(55);
string tmp[maxn];
string a[4]={ 
	"***ABCDE",
	"FGHIJKLM",
	"NOPQRSTU",
	"VWXYZ***",
};
bool vis[4][9]={0}; //标记 
string temp;
inline void work(char);
inline void print(void);

int main(){
	//ios::sync_with_stdio(false); 别开这个 
	int n;
	scanf("%d",&n);
	for(int i=0;i<n;++i){
		cin>>tmp[i];
		transform(tmp[i].begin(),tmp[i].end(),tmp[i].begin(),::toupper); //转换成大写 
	}
	cin>>temp;
	transform(temp.begin(),temp.end(),temp.begin(),::toupper);//转换成大写 
	int len=temp.length();
	for(int i=0;i<n;++i){
		string t=tmp[i].substr(0,len); //截取字符串 
		if(t!=temp) continue; //如果不相等的话就不进行判断 
		else {
			char c=tmp[i][len];
			work(c);
		}
	}
	print();
	return 0;
}
inline void work(char c){
	for(int i=0;i<4;++i){
		for(int j=0;j<8;++j){
			if(a[i][j]==c){
				vis[i][j]=1; //标记 
				break;
			}
		}
	}
}
inline void print(void){
	for(int i=0;i<4;++i){
		for(int j=0;j<8;++j){
			if(vis[i][j]==true) cout<<a[i][j]; //如果被标记就输出 
			else cout<<"*"; //否则输出* 
		}
		cout<<endl; //换行 
	}
}

 

点赞

发表评论

电子邮件地址不会被公开。 必填项已用*标注