EOJ 3256 拼音魔法 题解
题意
魔法学校小学一年级有一种题。就是给一个字的拼音,给一个声调,让你正确地注音。但魔法老师给了巨量的题,你不用魔法根本不可能做完。所以现在要让你发明一种魔法完成这个任务。
问题已经讲完了,下面开始教授汉语。(会汉语或者自认为会汉语的可以自动跳过)
汉语中一个字的拼音由声母和韵母两部分组成,在极少数情况下也会没有声母,但一定有韵母。
一般认为,声母有 b, p, m, f, d, t, l, n, g, k, h, j, q, x, z, c, s, zh, ch, sh, r, y, w;韵母有:a, e, o, i, u, ü, ai, ei, ui, ao, ou, iu, ie, üe, er, an, en, in, un, ün, ang, eng, ing, ong。
不是所有的字母都能组合的,组合的时候有时会发生一些神奇的事情,例如 üe 变成了 ue。但是标调规则有如下口诀:
有 a 先找 a,没 a 找 o e,i u 并排标在后,这样标调不会错。
只有下面列出的元素可能会被标调。请按照下表输出(尤其注意 a 不要输出成 ɑ 了):
第一声:ā ē ī ō ū ǖ。
第二声:á é í ó ú ǘ。
第三声:ǎ ě ǐ ǒ ǔ ǚ。
第四声:à è ì ò ù ǜ。
轻声:a e i o u ü。
辅助材料:由教育部公布的拼音方案。如果有描述不一致的地方,请以本题描述为准。
思路
模拟,用string规避编码问题
代码
#include <cstdio>
#include <iostream>
#include <string>
using namespace std;
string ss[5][8]={"a","o","e","iu","ui","i","u","ü","ā","ō","ē","iū","uī","ī","ū","ǖ","á","ó","é","iú","uí","í","ú","ǘ","ǎ","ǒ","ě","iǔ","uǐ","ǐ","ǔ","ǚ","à","ò","è","iù","uì","ì","ù","ǜ"};
int main()
{int T;string s;string::size_type pos;int len;cin>>T;for(int kase=1;kase<=T;kase++){cin>>s;cout<<"Case "<<kase<<": ";pos=s.find("v",0);if(pos!=string::npos)s=s.substr(0,pos)+"ü"+s.substr(pos+1,s.length()-pos-1);if(s[s.length()-1]<'1'||s[s.length()-1]>'4')cout<<s<<endl;else{for(int i=0;i<8;i++){pos=s.find(ss[0][i],0);if(pos!=string::npos){len=s.length();s=s.substr(0,pos)+ss[s[len-1]-'0'][i]+s.substr(pos+ss[0][i].length(),len-pos-ss[0][i].length()-1);cout<<s<<endl;break;}}}}return 0;
}
EOJ 3256 拼音魔法 题解相关推荐
- EOJ 3256 拼音魔法 【模拟】
题目链接:EOJ 3256 Description: 魔法学校小学一年级有一种题.就是给一个字的拼音,给一个声调,让你正确地注音.但魔法老师给了巨量的题,你不用魔法根本不可能做完.所以现在要让你发明一 ...
- EOJ 3256 拼音魔法(string+char[]的使用技巧)
拼音魔法 Time limit per test: 1.0 seconds Time limit all tests: 1.0 seconds Memory limit: 256 megabytes ...
- EOJ 3256:拼音魔法
拼音魔法 Time limit per test: 1.0 seconds Time limit all tests: 1.0 seconds Memory limit: 256 megabytes ...
- 拼音魔法 使用switch case简化复杂的if else
A. 拼音魔法 原题链接 魔法学校小学一年级有一种题.就是给一个字的拼音,给一个声调,让你正确地注音.但魔法老师给了巨量的题,你不用魔法根本不可能做完.所以现在要让你发明一种魔法完成这个任务. 问题已 ...
- 拼音魔法-华东师范大学程序设计竞赛-ecnu3256
拼音魔法click here 模拟题,轻声判断v转换为u还是ü:1至4升是一样的解法.先判断有无a o e, 若有,替换为带声调的:若无,继续判断有无i u,若有,替换:若无,继续判断有无v,若有,替 ...
- 2017华东师范大学网赛-拼音魔法
拼音魔法 Time limit per test: 1.0 seconds Time limit all tests: 1.0 seconds Memory limit: 256 megabytes ...
- A. 拼音魔法(模拟)
摸了200+,丢人啊 A. 拼音魔法 Time limit per test: 1.0 seconds Time limit all tests: 1.0 seconds Memory limit: ...
- 2017大学生程序设计邀请赛(华东师范大学) A.拼音魔法
传送门:http://acm.ecnu.edu.cn/problem/3256/ 魔法学校小学一年级有一种题.就是给一个字的拼音,给一个声调,让你正确地注音.但魔法老师给了巨量的题,你不用魔法根本不可 ...
- A. 拼音魔法 ecnu
Time limit per test: 1.0 seconds Time limit all tests: 1.0 seconds Memory limit: 256 megabytes Accep ...
最新文章
- PyTorch深度学习
- 查看LINUX进程内存占用情况
- iOS 简简单单构造单例
- vue中如何解决touch和click共存的问题
- 小技巧!CSS 整块文本溢出省略特性探究
- mysql过滤效率和java过滤效率_熔喷布过滤效率测试仪详解
- linux 的空命令:(冒号)
- Zabbix 系统监控(二)Linux 系统监控
- 在datasnap 中使用unidac 访问数据(客户端)
- 红帽新 Logo 为何要移除黑影人?
- bin文件用cad打开_bin文件 打开方法_win7如何打开bin 格式的文件图文步骤
- PC端 流光溢彩 Arduino
- php aria2离线下载器,下载神器——Aria2,打造你自己的离线下载服务器
- 没Switch也能玩有氧拳击 咕咚智能运动手表F4全面评测
- openlayer4加载arcgis rest服务(遥感影像切片)
- SAP FICO 理解成本中心会计
- 国防科技大学计算机考纲,国防科技大学2022年硕士研究生考试大纲-F1007雷达原理...
- Java毕设项目:智慧校园管理系统
- Java学习day18-集合框架2(泛型,工具类,TreeMap)
- 【js调用后端接口】
热门文章
- 侯捷C++个人学习笔记面向对象Part2
- noj14求广义表深度
- linux中groupadd命令详解,adduser和addgroup命令讲解
- 影响网站收录与排名的一些因素
- 2018 acm-icpc南京站 复盘
- 【学习总结Day32】
- 在Excel2003中,用A表示第1列,B表示第2列。。。Z表示第26列,AA表示第27列,AB表示第28列。。。以此类推。请写出一个函数,输入用字母表示的列号编码,输出它是第几列
- 基于idea使用技巧
- OpenCV函数学习:cvRound,cvFloor,cvCeil
- [RS] 类别数据数字化的方法 —— LabelEncoder VS OneHotEncoder (虚拟变量陷阱(Dummy Variable Trap))