HDU 1736 美观化文字

美观化文字

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 4009    Accepted Submission(s): 881

Problem Description

请看下面两段文字:

Kenny喊道:"我来了!"

Kenny喊道:“我来了!”

前面一段文字中由于在中文中使用了英文标点,显得不太美观。本题中你的任务是让任意一段文字美观化。美观化具体要求为将以下字符(串)转换为对应的中文字符:

英文 中文 ,    , .    。 !    ! "    “或” <<   《>>    》 ?    ?

Input

输入文字只有一段。文字中可能含有中英文、符号以及控制符(换行、空格、制表符等)。

Output

按照要求输出美化后的文字段。你不用翻译以上指定的符号之外的所有字符

Sample Input

Kenny喊道:"我来了!"

Sample Output

Kenny喊道:“我来了!”

Hint

你可以认为所有中文字符由两个字节组成,首字节的ASCII值都大于127(也可以理解为signed char型小于0)

Author

JGShining(极光炫影)

Source

“网新恩普杯”杭州电子科技大学程序设计邀请赛

解析:细节题。输入文字是一段,而不是一行。并且文字本身可能含有中文引号,注意判断方式,因为中文的引号有前后之分。

 1 #include <cstdio>
 2 #include <string>
 3 using namespace std;
 4
 5 char s[201000];
 6
 7 int main()
 8 {
 9     while(gets(s)){
10         int sum = 0;
11         for(int i = 0; s[i] != ‘\0‘; ++i){
12             string tmp("");
13             tmp = tmp+s[i]+s[i+1];   //构造成字符串,判断中文引号,写成tmp += s[i]+s[i+1]会得到WA。
14             if(tmp == "“" || tmp == "”")
15                 ++sum;
16             if(s[i] == ‘"‘){
17                 if(sum%2 == 0)
18                     printf("“");
19                 else
20                     printf("”");
21                 ++sum;
22             }
23             else if(s[i] == ‘,‘) printf(",");
24             else if(s[i] == ‘.‘) printf("。");
25             else if(s[i] == ‘!‘) printf("!");
26             else if(s[i] == ‘?‘) printf("?");
27             else if(s[i] == ‘<‘ && s[i+1] == ‘<‘){
28                 ++i;
29                 printf("《");
30             }
31             else if(s[i] == ‘>‘ && s[i+1] == ‘>‘){
32                 ++i;
33                 printf("》");
34             }
35             else
36                 printf("%c", s[i]);
37         }
38         printf("\n");   //补上gets后的‘\n‘
39     }
40     return 0;
41 }
时间: 2024-08-05 10:30:31

HDU 1736 美观化文字的相关文章

美观化文字《汉字的切割问题》

注意:你可以认为所有中文字符由两个字节组成,首字节的ASCII值都大于127(也可以理解为signed char型小于0) 题目: 请看下面两段文字: Kenny喊道:"我来了!" Kenny喊道:"我来了!" 前面一段文字中由于在中文中使用了英文标点,显得不太美观.本题中你的任务是让任意一段文字美观化.美观化具体要求为将以下字符(串)转换为对应的中文字符: 英文 中文 , , . . ! ! " "或" << <&g

HDU 1078 记忆化搜索

FatMouse and Cheese Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 4575 Accepted Submission(s): 1829 Problem Description FatMouse has stored some cheese in a city. The city can be considered as a

hdu 1717 小数化分数2 (数论)

点我点我点我!!! 接下来要做的就是模拟上述过程了. 静下来想一下自己要得到的信息. 然后拿出来,就可以了,模拟嘛,都是这样的. #include <iostream> #include <cstdio> #include <cstring> #include <algorithm> using namespace std; char str[20]; int gcd(int a,int b) { return a%b==0?b:gcd(b,a%b); }

hdu 4960 记忆化搜索 DP

Another OCD Patient Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) Total Submission(s): 490    Accepted Submission(s): 180 Problem Description Xiaoji is an OCD (obsessive-compulsive disorder) patient. This morni

hdu 3644 记忆化搜索

题目:给出一个有向图,从1到n,每个结点有个权值,每走一步,分值为结点权值的LCM,而且每一步的LCM都要有变化,问到达N的时候分值恰好为K的路径有多少条 记忆化搜索,虽然做过很多了,但是一直比较慢,这次总结出几点 1.注意确定终点状态 2.状态的初始化 3.不可能状态的排除 代码是参考cxlove写的,kuangbin博客要是刷完了,下一个就刷他啦 1 #include<cstdio> 2 #include<iostream> 3 #include<algorithm>

hdu 1342 记忆化深搜

Lotto Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 1657    Accepted Submission(s): 811 Problem Description In a Lotto I have ever played, one has to select 6 numbers from the set {1,2,...,49

HDU 1072(记忆化BFS)

题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1072 题目大意:走迷宫.走到装置点重置时间,到达任一点时的时间不能为0,可以走重复路,求出迷宫最短时间. 解题思路: vis的第三维标记一下到这个格子的时间. 尽管可以格子可以重复走,但在相同时间到这个格子是没有意义的. 小心一下时间不能为0的问题就行了. #include "cstdio" #include "queue" #include "cstrin

hdu 1978 记忆化搜索

How many ways Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 5203    Accepted Submission(s): 3067 Problem Description 这是一个简单的生存游戏,你控制一个机器人从一个棋盘的起始点(1,1)走到棋盘的终点(n,m).游戏的规则描述如下:1.机器人一开始在棋盘的起始点并有起

HDU 1978 记忆化搜索(dfs+dp)

Y - How many ways Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status Practice HDU 1978 Appoint description: Description 这是一个简单的生存游戏,你控制一个机器人从一个棋盘的起始点(1,1)走到棋盘的终点(n,m).游戏的规则描述如下: 1.机器人一开始在棋盘的起始点并有起始点所标有的能量. 2.机器