您的位置:首页 > 其它

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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: