HDU 1736 美观化文字
2016-05-20 17:24
316 查看
美观化文字
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 4009 Accepted Submission(s): 881
[align=left]Problem Description[/align]
请看下面两段文字:
Kenny喊道:"我来了!"
Kenny喊道:“我来了!”
前面一段文字中由于在中文中使用了英文标点,显得不太美观。本题中你的任务是让任意一段文字美观化。美观化具体要求为将以下字符(串)转换为对应的中文字符:
英文 中文 , , . 。 ! ! " “或” << 《 >> 》 ? ?
[align=left]Input[/align]
输入文字只有一段。文字中可能含有中英文、符号以及控制符(换行、空格、制表符等)。
[align=left]Output[/align]
按照要求输出美化后的文字段。你不用翻译以上指定的符号之外的所有字符。
[align=left]Sample Input[/align]
Kenny喊道:"我来了!"
[align=left]Sample Output[/align]
Kenny喊道:“我来了!”
Hint
你可以认为所有中文字符由两个字节组成,首字节的ASCII值都大于127(也可以理解为signed char型小于0)
[align=left]Author[/align]
JGShining(极光炫影)
[align=left]Source[/align]
“网新恩普杯”杭州电子科技大学程序设计邀请赛
解析:细节题。输入文字是一段,而不是一行。并且文字本身可能含有中文引号,注意判断方式,因为中文的引号有前后之分。
#include <cstdio> #include <string> using namespace std; char s[201000]; int main() { while(gets(s)){ int sum = 0; for(int i = 0; s[i] != '\0'; ++i){ string tmp(""); tmp = tmp+s[i]+s[i+1]; //构造成字符串,判断中文引号,写成tmp += s[i]+s[i+1]会得到WA。 if(tmp == "“" || tmp == "”") ++sum; if(s[i] == '"'){ if(sum%2 == 0) printf("“"); else printf("”"); ++sum; } else if(s[i] == ',') printf(","); else if(s[i] == '.') printf("。"); else if(s[i] == '!') printf("!"); else if(s[i] == '?') printf("?"); else if(s[i] == '<' && s[i+1] == '<'){ ++i; printf("《"); } else if(s[i] == '>' && s[i+1] == '>'){ ++i; printf("》"); } else printf("%c", s[i]); } printf("\n"); //补上gets后的'\n' } return 0; }
相关文章推荐
- Git学习笔记3
- keepalived 知识备注
- iOS-CollectionView 基础
- PowerPoint轻松实现列表播放功能
- 图像处理工具类、Bitmap处理、理解ThumbnailUtils
- win7下环境搭建
- [Android]实现静默安装APK的两种方法
- leetcode 189. Rotate Array-旋转数组
- 单例设计模式
- MSSQL exists与not exists; in与not in的区别
- Java中 obj.toString()和String.valueof()
- jquery源码分析
- 找水王
- 环形字符串最小最大表示法
- Leetcode 36.Valid Sudoku
- 利用googleZxing生成二维码识别二维码
- js代码定时执行一个方法,延迟一定时间后执行一个函数
- Android UiAutomator UiSelector类
- 遥感图去黑边
- 大型网站技术架构 学习总结一(基础了解)