欢迎访问我的新博客:http://www.milkcu.com/blog/

原文地址:http://www.milkcu.com/blog/archives/1366788180.html

题目描述

【编程题】(满分19分)

在很多软件中,输入拼音的首写字母就可以快速定位到某个词条。比如,在铁路售票软件中,输入: “bj”就可以定位到“北京”。怎样在自己的软件中实现这个功能呢?问题的关键在于:对每个汉字必须能计算出它的拼音首字母。

GB2312汉字编码方式中,一级汉字的3755个是按照拼音顺序排列的。我们可以利用这个特征,对常用汉字求拼音首字母。

GB2312编码方案对每个汉字采用两个字节表示。第一个字节为区号,第二个字节为区中的偏移号。为了能与已有的ASCII编码兼容(中西文混排),区号和偏移编号都从0xA1开始。

我们只要找到拼音a,b,c,...x,y,z 每个字母所对应的GB2312编码的第一个汉字,就可以定位所有一级汉字的拼音首字母了(不考虑多音字的情况)。下面这个表给出了前述信息。请你利用该表编写程序,求出常用汉字的拼音首字母。

a 啊 B0A1
b 芭 B0C5
c 擦 B2C1
d 搭 B4EE
e 蛾 B6EA
f 发 B7A2
g 噶 B8C1
h 哈 B9FE
j 击 BBF7
k 喀 BFA6
l 垃 C0AC
m 妈 C2E8
n 拿 C4C3
o 哦 C5B6
p 啪 C5BE
q 期 C6DA
r 然 C8BB
s 撒 C8F6
t 塌 CBFA
w 挖 CDDA
x 昔 CEF4
y 压 D1B9
z 匝 D4D1

【输入、输出格式要求】

用户先输入一个整数n (n<100),表示接下来将有n行文本。接着输入n行中文串(每个串不超过50个汉字)。

程序则输出n行,每行内容为用户输入的对应行的汉字的拼音首字母。

字母间不留空格,全部使用大写字母。

例如:
    用户输入:
3
大家爱科学
北京天安门广场
软件大赛

则程序输出:
DJAKX
BJTAMGC
RJDS

【注意】

请仔细调试!您的程序只有能运行出正确结果的时候才有机会得分!
    
    在评卷时使用的输入数据与试卷中给出的实例数据可能是不同的。

请把所有函数写在同一个文件中,调试好后,拷贝到【考生文件夹】下对应题号的“解答.txt”中即可。
    
    相关的工程文件不要拷入。
    
    源代码中不能使用诸如绘图、Win32API、中断调用、硬件操作或与操作系统相关的API。
    
    允许使用STL类库,但不能使用MFC或ATL等非ANSI c++标准的类库。

例如,不能使用CString类型(属于MFC类库),不能使用randomize, random函数(不属于ANSI C++标准)

分析

这是2012年第三届蓝桥杯全国软件大赛决赛的第三题,要求把输入的汉字转换为大写首字母并输出。程序主要包括2个模块:获得输入、判断字母并输出。这个“拼音字母”问题和“画表格”问题比较像,都是中文处理问题,两个char存储一个字符。对于下面的代码用了二维数组,造成空间的浪费,可以使用数组指针代替。

源代码

# include <stdio.h>
int main(void)
{int c;int i, j;int ch[100][101];int value;int n;scanf("%d", &n);getchar();  //屏蔽多输入的空格键 for(j = 0; j < n; j++) {i = 0;while((c = getchar()) != '\n') {ch[j][i++] = c;}ch[j][i] = '\n';}for(j = 0; j < n; j++) {i = 0;while(ch[j][i] != '\n') {value = ch[j][i] * 0x100 + ch[j][i+1];if(value >= 0xb0a1 && value < 0xb0c5) {putchar('A');} else if(value < 0xb2c1) {putchar('B');} else if(value < 0xb4ee) {putchar('C');} else if(value < 0xb6ea) {putchar('D');} else if(value < 0xb7a2) {putchar('E');} else if(value < 0xb8c1) {putchar('F');} else if(value < 0xb9fe) {putchar('G');} else if(value < 0xbbf7) {putchar('H');} else if(value < 0xbfa6) {putchar('J');} else if(value < 0xc0ac) {putchar('K');} else if(value < 0xc2e8) {putchar('L');} else if(value < 0xc4c3) {putchar('M');} else if(value < 0xc5b6) {putchar('N');} else if(value < 0xc5be) {putchar('O');} else if(value < 0xc6da) {putchar('P');} else if(value < 0xc8bb) {putchar('Q');} else if(value < 0xc8f6) {putchar('R');} else if(value < 0xcbfa) {putchar('S');} else if(value < 0xcdda) {putchar('T');} else if(value < 0xcef4) {putchar('W');} else if(value < 0xd1b9) {putchar('X');} else if(value < 0xd4d1) {putchar('Y');} else {putchar('Z');}i += 2;;}putchar('\n');}
}

“拼音字母”--蓝桥杯相关推荐

  1. 蓝桥杯---拼音字母

    拼音字母 (2012年第三届蓝桥杯C/C++程序设计本科B组决赛题目) 在很多软件中,输入拼音的首写字母就可以快速定位到某个词条.比如,在铁路售票软件中,输入: "bj"就可以定位 ...

  2. 2012年第三届蓝桥杯C/C++程序设计本科B组决赛 拼音字母(编程大题)

    2012年第三届蓝桥杯C/C++程序设计本科B组决赛题目汇总: http://blog.csdn.net/u014552756/article/details/51399827 拼音字母 在很多软件中 ...

  3. 2012第三届蓝桥杯预赛题

    1.      微生物增殖(用每半分钟作为一个增长量) 假设有两种微生物 X 和 Y X出生后每隔3分钟分裂一次(数目加倍),Y出生后每隔2分钟分裂一次(数目加倍). 一个新出生的X,半分钟之后吃掉1 ...

  4. 2012年第三届C/C++ B组蓝桥杯省赛真题

    2013年第四届C/C++ B组蓝桥杯省赛真题 真题 第一题:微生物增殖 第二题:福尔摩斯探险 第三题:比酒量 第四题:奇怪的比赛 第五题:方阵转置 第六题:大数乘法 第七题:放棋子 第八题:密码发生 ...

  5. 第三届蓝桥杯 c/c++真题

    第三届蓝桥杯真题 c/c++ 以下题目我自己也并不是所有的题目都是一次性就能做对或是有结题思路的.有些题目也是经过查证网上相关的资料或是参考了别人的代码和解题思路才做出来的.总的来看,这份题目考了很多 ...

  6. 金蝉素数c语言,算法笔记_204:第四届蓝桥杯软件类决赛真题(Java语言C组)

    前言:以下代码仅供参考,若有错误欢迎指正哦~ 1好好学习 汤姆跟爷爷来中国旅游.一天,他帮助中国的小朋友贴标语.他负责贴的标语是分别写在四块红纸上的四个大字:"好.好.学.习".但 ...

  7. 小唐开始刷蓝桥(九)2012年第三届C/C++ B组蓝桥杯省赛真题

    文章目录 前言 一.微生物增殖 二.古堡算式 三.比酒量 四.奇怪的比赛 五.方阵转置 六.大数乘法 七.放棋子 八.密码发生器 九.夺冠概率 十.取球游戏 上一篇: 小唐开始刷蓝桥(八)2013年第 ...

  8. 蓝桥杯2012省赛 简单题解 c++

    写在前面:肝了一晚上方舟,我终于想起来搞博客了(陨星新皮肤真好看 嘿嘿 嘿嘿)..退役了两次的老咸鱼终于又回来了,虽然很想就这样一直咸鱼下去,但是过去的种种遗憾一直膈应着我.我知道我过去做错过许多事, ...

  9. 蓝桥杯训练题目若干(东华20考研挑战题1-50)

    文章目录 前言 1 Huffuman树 2 回文数 3 字母图形 4 大阶乘计算 5 回形取数 6 龟兔赛跑预测 7 Sine之舞 8 矩形面积交 9 矩阵乘法 10 分解质因数 11 字符串对比 1 ...

最新文章

  1. linux线程池实现多线程并发,基于Linux的多线程池并发Web服务器设计-电子设计工程.PDF...
  2. C++拷贝构造函数详解
  3. Bind和Eval的区别详解
  4. 创建一个HTML文件
  5. Java 8 Friday Goodies:Lambda和SQL
  6. 判断iframe是否加载完成的方法[转]
  7. Python数据结构常见的八大排序算法(详细整理)
  8. java url特殊字符转义字符_URL中包含有特殊字符,进行转义
  9. 炫酷引导页带视频源码
  10. Oculus首席科学家发声,称VR需要能够“欺骗”大脑
  11. CentOS SSH配置
  12. php方法 隐藏手机号中间四位
  13. windows环境下zookeeper做成服务并启动
  14. 惠州学计算机技校有什么条件,惠州惠城区技工学校2020年学费、收费多少
  15. CSS图片保持原比例
  16. Linux系统的grub.cfg文件损坏修复
  17. Python 遍历文件夹下所有文件 合并txt内容
  18. python 3d库_python的3d库
  19. 新版火狐浏览器安装xpath插件
  20. 盘点:2019年好用的设备管理系统软件,你都用过吗?

热门文章

  1. Vue2.0中使用ES6
  2. 如何跳出forEach循环
  3. 基于web的智能考勤系统设计与实现
  4. crypto isakmp keepalive
  5. VBA 第8课 Excel单元格的颜色,格式的设置
  6. 达人评测 r7 5700g对比i7 11700k选哪个
  7. JAVA 上传图片时 压缩后上传
  8. 职场高薪 |「中高级测试」面试题
  9. oracle外键--详解
  10. html基本知识点(看了就能懂)