PTA 模拟【string以及字母->数组下标】
假设有九宫格输入法键盘布局如下:
[ 1,.?! ] [ 2ABC ] [ 3DEF ]
[ 4GHI ] [ 5JKL ] [ 6MNO ]
[ 7PQRS ] [ 8TUV ] [ 9WXYZ ]
[ 0空 ]
注意:中括号[ ]仅为了表示键盘的分隔,不是输入字符。每个中括号中,位于首位的数字字符即是键盘的按键,按一下即可输入该数字字符。多次按同一个键,则输入的字符依次循环轮流,例如按两次3,则输入D;按5次7,则输入S;按6次2,则输入A。按键0的输入组合是0和空格字符,即按两次0输入空格。
你需要对于给定的按键组合,给出该组合对应的文本。
输入格式:
输入在一行中给出数个字符的按键组合(例如 999 表示按3次9),每个字符的按键组合之间用空格间隔,最后一个输入法组合之后以换行结束。输入数据至少包括一个字符的按键组合,且输入总长度不超过500个字符。
输出格式:
在一行中输出该按键组合对应的文本。
输入样例:
22 5555 22 666 00 88 888 7777 4444 666 44
输出样例:
ALAN TURING
厂长的代码。。。。。。好看。。。
string s[]={"0 ", "1,.?!", "2ABC", "3DEF", "4GHI", "5JKL", "6MNO", "7PQRS", "8TUV", "9WXYZ"};
char ss[505];
int main()
{
while(~scanf("%s", ss))
{
int n=strlen(ss)-1;
n%=s[ss[0]-'0'].length();
putchar(s[ss[0]-'0'][n]);
}
puts("");
return 0;
}
我的代码。。懒得改了//
。。。。
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int, int> PI;
typedef pair< PI, int> PII;
const double eps=1e-5;
const double pi=acos(-1.0);
const int mod=1e9+7;
const int INF=0x3f3f3f3f;
const int MAXN=1100;
#define lson l, m, rt<<1
#define rson m+1, r, rt<<1|1
const int N=1e4+10;
int n;
char s[N];
char ans[N];
void solve(char c,int num)
{
if(c=='0'){
if(num==1)
ans[n++]='0';
else
ans[n++]=' ';
}
else if(c=='1'){
if(num==1){
ans[n++]='1';
}
else if(num==2){
ans[n++]=',';
}
else if(num==3){
ans[n++]='.';
}
else if(num==4){
ans[n++]='?';
}
else if(num==0){
ans[n++]='!';
}
}
else if(c=='2'){
if(num==1){
ans[n++]='2';
}
else if(num==2){
ans[n++]='A';
}
else if(num==3){
ans[n++]='B';
}
else if(num==0){
ans[n++]='C';
}
}
else if(c=='3'){
if(num==1){
ans[n++]='3';
}
else if(num==2){
ans[n++]='D';
}
else if(num==3){
ans[n++]='E';
}
else if(num==0){
ans[n++]='F';
}
}
else if(c=='4'){
if(num==1){
ans[n++]='4';
}
else if(num==2){
ans[n++]='G';
}
else if(num==3){
ans[n++]='H';
}
else if(num==0){
ans[n++]='I';
}
}
else if(c=='5'){
if(num==1){
ans[n++]='5';
}
else if(num==2){
ans[n++]='J';
}
else if(num==3){
ans[n++]='K';
}
else if(num==0){
ans[n++]='L';
}
}
else if(c=='6'){
if(num==1){
ans[n++]='6';
}
else if(num==2){
ans[n++]='M';
}
else if(num==3){
ans[n++]='N';
}
else if(num==0){
ans[n++]='O';
}
}
else if(c=='7'){
if(num==1){
ans[n++]='7';
}
else if(num==2){
ans[n++]='P';
}
else if(num==3){
ans[n++]='Q';
}
else if(num==4){
ans[n++]='R';
}
else if(num==0){
ans[n++]='S';
}
}
else if(c=='8'){
if(num==1){
ans[n++]='8';
}
else if(num==2){
ans[n++]='T';
}
else if(num==3){
ans[n++]='U';
}
else if(num==0){
ans[n++]='V';
}
}
else if(c=='9'){
if(num==1){
ans[n++]='9';
}
else if(num==2){
ans[n++]='W';
}
else if(num==3){
ans[n++]='X';
}
else if(num==4){
ans[n++]='Y';
}
else if(num==0){
ans[n++]='Z';
}
}
}
int main()
{
gets(s);
int len;
char c;
int num,flag;
len=strlen(s);
num=flag=n=0;
for(int i=0;i<len;i++){
if(s[i]!=' '){
c=s[i];
num++;
flag=1;
}
else if(s[i]==' '){
if(c=='1'||c=='7'||c=='9')
num%=5;
if(c=='2'||c=='3'||c=='4'||c=='5'||c=='6'||c=='8')
num%=4;
if(c=='0')
num%=2;
solve(c,num);
num=0;
flag=0;
}
}
if(flag){
if(c=='1'||c=='7'||c=='9')
num%=5;
if(c=='2'||c=='3'||c=='4'||c=='5'||c=='6'||c=='8')
num%=4;
if(c=='0')
num%=2;
solve(c,num);
}
ans[n]='\0';
printf("%s",ans);
return 0;
}
/*
22 5555555555 22 666 00 88 888 7777 4444 666 44
*/
PTA 模拟【string以及字母->数组下标】的更多相关文章
- C++程序设计方法3:数组下标运算符重载
数组下标运算符重载 函数声明形式 返回类型operator[](参数): 如果返回类型是引用,则数组运算符调用可以出现在等式的左边,接受赋值,即: Obj[index] = value; 如果返回类型 ...
- 【c++习题】【17/5/22】重载数组下标操作符
一.写出程序运行结果 1#include <iostream > using namespace std; int a[10]={1,2, 3, 4, 5, 6, 7, 8, 9, 10} ...
- Codeforces Round #279 (Div. 2)B. Queue(构造法,数组下标的巧用)
这道题不错,思维上不难想到规律,但是如何写出优雅的代码比较考功力. 首先第一个人的序号可以确定,那么接下来所有奇数位的序号就可以一个连一个的确定了.然后a[i].first==0时的a[i].seco ...
- 二叉搜索树的结构(30 分) PTA 模拟+字符串处理 二叉搜索树的节点插入和非递归遍历
二叉搜索树的结构(30 分) PTA 模拟+字符串处理 二叉搜索树的节点插入和非递归遍历 二叉搜索树的结构(30 分) 二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则 ...
- 网易云课堂_C++程序设计入门(下)_第8单元:年年岁岁花相似– 运算符重载_第8单元 - 作业2:OJ编程 - 重载数组下标运算符
第8单元 - 作业2:OJ编程 - 重载数组下标运算符 查看帮助 返回 温馨提示: 1.本次作业属于Online Judge题目,提交后由系统即时判分. 2.学生可以在作业截止时间之前不限次数提 ...
- Leetcode541/151之String与char数组与StringBuffer
String与char数组与StringBuffer 通常情况下遇到删除字符或者反转字符串时需要将String转为char数组或者StringBuffer String与char数组 char [] ...
- C——数组下标与间址运算符
只说一句,数组下标与间址运算符*是等价的,即:a[i] = *(a+i),看代码: int main(int argc, char* argv[]) { ] = {, , , , }; int i; ...
- PChar,PAnsiChar,String,AnsiString,Char数组,AnsiChar数组转换
PChar,PAnsiChar,String,AnsiString,Char数组,AnsiChar数组之间的转换关系见下图 通过转换链,可以实现任意两个类型之间的互转.如PChar转PAnsiChar ...
- bash中不可以用字符串做数组下标
bash中可以用字符串做数组下标吗例如 test["abc"]=1------解决方案-------------------- 好像是误会,是awk里可以,bash shell里不 ...
随机推荐
- Koala - 使用
几天项目又加紧,样式想写又太慢! 下载考拉:http://pc6.dun.123ch.cn/download/koala%E7%BC%96%E8%AF%91%E5%B7%A5%E5%85%B7_30@ ...
- nginx 配置nginx.conf,负载均衡,逻辑分流
nginx 最重要的配置文件nginx.conf: 一般的配置我不做解释,网上到处都是,主要对主要的几点进行注释(如下) worker_processes ; error_log /data/logs ...
- cocos2d-x 3.0 touch事件官方解释
官方解释 http://www.cocos2d-x.org/docs/manual/framework/native/input/event-dispatcher/zh#_1
- innodb 乐观插入因空间不够导致失败,进入悲观插入阶段,这个空间的大小限制
btr_cur_optimistic_insert{ ... /*检查分裂页时是否有足够的空间预留给未来记录的update*/ if (leaf && !zip_size && ...
- python第三方库系列之十八--python/django test库
django是属于python语音的web框架,要说django測试.也能够先说说python的測试.django能够用python的方式測试,当然,django也基于python封装了一个自己的測试 ...
- [攻防实战]CTF大赛准备(手动注入sql)
一.IIS write漏洞利用 先用工具扫描,再上传小马,使用菜刀连接即可. 思考点: 如何获知是一台IIS站点? 本例中上传的一句话木马是什么意思? <%eval request(" ...
- log4j 路径环境变量配置和log4j加载配置
1.lo4j日志路径从环境变量读取,log4j.xml配置如下: 具体配置如下: log4j.appender.R.Encoding=UTF-8 log4j.appender.R=org.apache ...
- Delphi ActiveForm发布全攻略
论坛上很多朋友(也包括我)提到ActiveForm的发布问题,都没有得到很好的解决.下面是本人开发ActiveForm的一点经验,拿出来跟大家分享,开发环境为 Win2000Server,IIS5.0 ...
- eclipse软件启动弹窗端口问题解决
如果启动eclipse,弹出一个窗口,上面显示,8080 .8009.……等的提示,说明端口有冲突, 解决办法如下: 1.打开cmd 2.输入 netstat -ano|findstr 8080 ...
- MYSQL初级学习笔记四:查询数据的操作DQL(SELECT基本形式)(26-35)
知识点六:查询数据的操作DQL(SELECT基本形式)(26-35) CREATE DATABASE IF NOT EXISTS cms DEFAULT CHARACTER SET utf8; USE ...