题意

魔法学校小学一年级有一种题。就是给一个字的拼音,给一个声调,让你正确地注音。但魔法老师给了巨量的题,你不用魔法根本不可能做完。所以现在要让你发明一种魔法完成这个任务。
问题已经讲完了,下面开始教授汉语。(会汉语或者自认为会汉语的可以自动跳过)
汉语中一个字的拼音由声母和韵母两部分组成,在极少数情况下也会没有声母,但一定有韵母。
一般认为,声母有 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 拼音魔法 题解相关推荐

  1. EOJ 3256 拼音魔法 【模拟】

    题目链接:EOJ 3256 Description: 魔法学校小学一年级有一种题.就是给一个字的拼音,给一个声调,让你正确地注音.但魔法老师给了巨量的题,你不用魔法根本不可能做完.所以现在要让你发明一 ...

  2. EOJ 3256 拼音魔法(string+char[]的使用技巧)

    拼音魔法 Time limit per test: 1.0 seconds Time limit all tests: 1.0 seconds Memory limit: 256 megabytes ...

  3. EOJ 3256:拼音魔法

    拼音魔法 Time limit per test: 1.0 seconds Time limit all tests: 1.0 seconds Memory limit: 256 megabytes ...

  4. 拼音魔法 使用switch case简化复杂的if else

    A. 拼音魔法 原题链接 魔法学校小学一年级有一种题.就是给一个字的拼音,给一个声调,让你正确地注音.但魔法老师给了巨量的题,你不用魔法根本不可能做完.所以现在要让你发明一种魔法完成这个任务. 问题已 ...

  5. 拼音魔法-华东师范大学程序设计竞赛-ecnu3256

    拼音魔法click here 模拟题,轻声判断v转换为u还是ü:1至4升是一样的解法.先判断有无a o e, 若有,替换为带声调的:若无,继续判断有无i u,若有,替换:若无,继续判断有无v,若有,替 ...

  6. 2017华东师范大学网赛-拼音魔法

    拼音魔法 Time limit per test: 1.0 seconds Time limit all tests: 1.0 seconds Memory limit: 256 megabytes ...

  7. A. 拼音魔法(模拟)

    摸了200+,丢人啊 A. 拼音魔法 Time limit per test: 1.0 seconds Time limit all tests: 1.0 seconds Memory limit: ...

  8. 2017大学生程序设计邀请赛(华东师范大学) A.拼音魔法

    传送门:http://acm.ecnu.edu.cn/problem/3256/ 魔法学校小学一年级有一种题.就是给一个字的拼音,给一个声调,让你正确地注音.但魔法老师给了巨量的题,你不用魔法根本不可 ...

  9. A. 拼音魔法 ecnu

    Time limit per test: 1.0 seconds Time limit all tests: 1.0 seconds Memory limit: 256 megabytes Accep ...

最新文章

  1. PyTorch深度学习
  2. 查看LINUX进程内存占用情况
  3. iOS 简简单单构造单例
  4. vue中如何解决touch和click共存的问题
  5. 小技巧!CSS 整块文本溢出省略特性探究
  6. mysql过滤效率和java过滤效率_熔喷布过滤效率测试仪详解
  7. linux 的空命令:(冒号)
  8. Zabbix 系统监控(二)Linux 系统监控
  9. 在datasnap 中使用unidac 访问数据(客户端)
  10. 红帽新 Logo 为何要移除黑影人?
  11. bin文件用cad打开_bin文件 打开方法_win7如何打开bin 格式的文件图文步骤
  12. PC端 流光溢彩 Arduino
  13. php aria2离线下载器,下载神器——Aria2,打造你自己的离线下载服务器
  14. 没Switch也能玩有氧拳击 咕咚智能运动手表F4全面评测
  15. openlayer4加载arcgis rest服务(遥感影像切片)
  16. SAP FICO 理解成本中心会计
  17. 国防科技大学计算机考纲,国防科技大学2022年硕士研究生考试大纲-F1007雷达原理...
  18. Java毕设项目:智慧校园管理系统
  19. Java学习day18-集合框架2(泛型,工具类,TreeMap)
  20. 【js调用后端接口】

热门文章

  1. 侯捷C++个人学习笔记面向对象Part2
  2. noj14求广义表深度
  3. linux中groupadd命令详解,adduser和addgroup命令讲解
  4. 影响网站收录与排名的一些因素
  5. 2018 acm-icpc南京站 复盘
  6. 【学习总结Day32】
  7. 在Excel2003中,用A表示第1列,B表示第2列。。。Z表示第26列,AA表示第27列,AB表示第28列。。。以此类推。请写出一个函数,输入用字母表示的列号编码,输出它是第几列
  8. 基于idea使用技巧
  9. OpenCV函数学习:cvRound,cvFloor,cvCeil
  10. [RS] 类别数据数字化的方法 —— LabelEncoder VS OneHotEncoder (虚拟变量陷阱(Dummy Variable Trap))