PTA --- 天梯赛 L1-059 敲笨钟
L1-059 敲笨钟 (20 point(s))
微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。为了增加敲钟的趣味性,还会糟改几句古诗词。其糟改的方法为:去网上搜寻压“ong”韵的古诗词,把句尾的三个字换成“敲笨钟”。例如唐代诗人李贺有名句曰:“寻章摘句老雕虫,晓月当帘挂玉弓”,其中“虫”(chong)和“弓”(gong)都压了“ong”韵。于是这句诗就被糟改为“寻章摘句老雕虫,晓月当帘敲笨钟”。
现在给你一大堆古诗词句,要求你写个程序自动将压“ong”韵的句子糟改成“敲笨钟”。
输入格式:
输入首先在第一行给出一个不超过 20 的正整数 N。随后 N 行,每行用汉语拼音给出一句古诗词,分上下两半句,用逗号 , 分隔,句号 . 结尾。相邻两字的拼音之间用一个空格分隔。题目保证每个字的拼音不超过 6 个字符,每行字符的总长度不超过 100,并且下半句诗至少有 3 个字。
输出格式:
对每一行诗句,判断其是否压“ong”韵。即上下两句末尾的字都是“ong”结尾。如果是压此韵的,就按题面方法糟改之后输出,输出格式同输入;否则输出 Skipped,即跳过此句。
输入样例:
xun zhang zhai ju lao diao chong, xiao yue dang lian gua yu gong.
tian sheng wo cai bi you yong, qian jin san jin huan fu lai.
xue zhui rou zhi leng wei rong, an xiao chen jing shu wei long.
zuo ye xing chen zuo ye feng, hua lou xi pan gui tang dong.
ren xian gui hua luo, ye jing chun shan kong.
输出样例:
xun zhang zhai ju lao diao chong, xiao yue dang lian qiao ben zhong.
Skipped
xue zhui rou zhi leng wei rong, an xiao chen jing qiao ben zhong.
Skipped
Skipped
代码:
#include<bits/stdc++.h>
using namespace std;
int main(){
int n;
cin >> n;
getchar();// 消除回车
while(n--){
string s = "";
getline(cin, s); //从标准输入 cin 输入字符串 保存到 s 中
int a = s.find(','); //返回 , 的下标
int b = s.find('.'); // 返回 . 的下标
// 前句至少3个字符,后句至少三个字【注意,是三个“字”,不是三个“字符”】,所以,"ong," 即 a >= 3 ,当a <= 2 时,skipped
if( a <= || (s.substr(a - 3, 3) != "ong" || s.substr(b - , ) != "ong")){ //裁分 substr 获得子字符串,比较之
cout << "Skipped\n";
continue;
}
else{
int sum = , k = ;
for(int i = s.size() - ; sum != ; i--){ // 从后往前搞 sum != 3
// "xxx xxxx xxxx xxxx."
if(s[i] == ' ')
sum++;
k = i;
}
s.replace(k + 1, s.size() - k, "qiao ben zhong.");
// 从 k + 1 开始,长度为 s.size() - k 的字符串,替换为 “qiao ben zhong.”
}
cout << s << endl;
}
return ;
}
总结:
思路上,主要是用各种函数方法 处理字符串,获取“,” 和 "." 等关键点的位置,再截取、处理、比较、替换字符串
代码总结:
1.#include<bits/stdc++.h>
包含了目前c++所包含的所有头文件
兼容性方面:
注意,目前POJ还不支持<bits/stdc++.h>(G++、C++都不支持)。HDU部分支持(G++支持,C++不支持)。
其他国外的oj,还有台湾的oj都支持,CF,Topcoder也都支持。
当然,其实这是一个偷懒的写法,但是会降低编译速度
笔试平台可以使用,方便,VS中并不支持,一般G++ 4.4以上就支持这个头文件了。当然,私下自己学习就不要去使用了,对你的自主学习一点都没有好处。
c++11支持
其余红色加重的函数方法 可见此处链接
https://www.cnblogs.com/expedition/p/11616279.html
2.string中getline,cin的方法getline(),get总结
详细的可以戳上方的链接,此处总结如下:
(1)string中的getline
getline不是string的成员函数,属于全局函数,使用需要include<string>
有两个重载版本:
getline (istream& is, string& str, char delim);
getline (istream& is, string& str);
这两个getline读取cin流里的字符串到str中,直到遇到下列情况结束,并返回:
(a)、遇到文件结束符,如windows下模拟的ctrl+z,或无效输入
(b)、遇到换行符,即Enter,将换行符留在缓冲区中,留给下一个输入,并不存入str中,所以输出str,要自己添加endl来换行
(c)、遇到设备故障
# str自动根据输入来调整大小。如何结束while(getline(cin,str))循环呢?可以使用ctrl+z
# 第三个参数为分界符,用户可以自定义,任何有效的字符都可以,如#,默认的为Enter。
(2)cin.getline
有两个重载版本
getline(char* s, streamsize n);
getline(char* s, streamsize n, char delim);
第一个参数为字符指针,第二个控制输入的最大字符(等于n-1,最后一个位置存'\0',以便把输入存为字符串)
如果输入的字符串过长,会导致cin流状态无效不能再输入。
使用cin.clear()函数可以重设cin的状态为有效。
注意:cin.getline() 会将分界符或者换行符丢弃,即缓冲区不会有分界符用于下一个输入。但是如果输入的字符串过长,余下的字符会留在缓冲区。
代码示例:
int main()
{
char c[];
cin.getline(c, );
cout << c;
}
输入的超过4个字符,只存入了 4 -1 个字符

int main()
{
char c[];
cin.getline(c, );
cout << c;
if (!cin) cout << "cin error" << endl;
cin.getline(c, ); // cin 会无效
}
如果输入的字符串过长,会导致cin流状态无效不能再输入。

int main()
{
char c[];
cin.getline(c, );
cout << c;
if (!cin) cout << "cin error" << endl;
cin.clear();
cin.sync();
cin.getline(c, );
cout << c << endl;
}
使用cin.clear()与cin.sync()(清空缓冲区),使cin 有效,才可以继续输入“123“

(3)cin.get
三个重载版本
get(char *,int,char);
get(char*,int);
get(char&);
函数都是istream类的方法,需要对象cin才能调用。
cin.get()与cin.getline()的不同之处为:遇到换行符或分界符,get会留该字符在缓冲区,所以cin.get()的连续两次调用,后一次会读取缓冲区的字符,不会再请求输入
所以,cin.get() 无法跨行输入
char c[];
char a[];
cin.get(c,);
cin.get(a,);
可以在cin.get(c,5)与cin.get(a,4)间插入cin.get()这条语句,读取了缓冲区的换行符
使之可以继续读取输入,而不是从缓冲区读取字符
(4)cin 的特点
用于输入int ,char ,string 等基本类型,不能输入一行字符到str中。cin遇到space,tab,Enter会自动忽略,从缓冲区中丢弃,但是后续的输入会留在缓冲区,下一次的输入会直接从缓冲区读取数据
int sum=;
int n;
while(cin>>n,n!=)
{
sum+=n;
}
cout<<sum<<endl;

# 注意:while(cin>>a,a!=20)的测试条件是逗号表达式,值为逗号右边的子表达式,而不是cin>>a的返回值cin。
# 注意:如果int a;cin>>a;输入的不是整数,cin>>a是无效输入,不能再输入。
PTA --- 天梯赛 L1-059 敲笨钟的更多相关文章
- PTA 天梯赛 L1
L1-002 打印沙漏 细节:就是在 (i>j&&i+j<r+1) 这个区间里才有空格,然后就是 for 循环 for(r=1; ;r+=2) 条件不满足之后还会再 ...
- L1-059 敲笨钟
微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉.为了增加敲钟的趣味性,还会糟改几句古诗词.其糟改的方法为:去网上搜寻压“ong”韵的古诗词,把句尾的三个字换成“敲笨钟”.例如唐代 ...
- L1-059 敲笨钟 (20 分)
微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉.为了增加敲钟的趣味性,还会糟改几句古诗词.其糟改的方法为:去网上搜寻压“ong”韵的古诗词,把句尾的三个字换成“敲笨钟”.例如唐代 ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 018-020
终于一周有这么一天能够安静下来好好学习打打题,还是很美滋滋的哈哈~加油加油~ ------------------------------------------------L1-018------- ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 001-006
应师兄要求,在打三月底天梯赛之前要把PTA上面的练习集刷完,所以后面的时间就献给PTA啦~ 后面每天刷的题都会把答案代码贡献出来,如果有好的思路想法也会分享一下~ 欢迎大佬提供更好的高效率算法鸭~ - ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 052-053
今日刷题,水题水题 ------------------------------------------------L1-052------------------------------------ ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 048-49
今日刷题048-049 ------------------------------------------------L1-048---------------------------------- ...
- 『ACM C++』 PTA 天梯赛练习集L1 | 040-41
近期安排 校赛3.23天梯赛3.30华工校赛 4.21省赛 5.12 ------------------------------------------------L1-040----------- ...
- 天梯赛L1 题解
L1-001 Hello World (5 分) 这道超级简单的题目没有任何输入. 你只需要在一行中输出著名短句“Hello World!”就可以了. AC代码:(直接输出记性) #include & ...
随机推荐
- phpStudy环境下composer的安装
前言 原来是做php开发的,现在转行前端工程师,因为很久没有接触了,可能会有其他问题,这里简单记录一下,后期遇到什么问题再进行更新~ 话说下载特别慢所以这里给个网盘链接Composer-Setup.e ...
- SQL Server 删除日志文件
-- 查询日志文件名,用于下面删除 USE [data_name] GO SELECT file_id, name FROM sys.database_files /*删除指定数据库的日志文件*/ U ...
- PHP:函数和语言结构(转)
转自:https://www.cnblogs.com/fanqiechaodan/articles/5222366.html 什么是语言结构呢?它和函数有什么不同吗? 1. 什么是语言结构和函数 语 ...
- BZOJ 3782: 上学路 Lucas+ExCRT+容斥+dp
其实呢,扩展中国剩余定理还有一种理解方式:就是你有一坨东西,形如:$A[i]\equiv B[i](mod$ $P[i])$. 对于这个东西,你可以这么思考:如果最后能求出一个解,那么这个解的增量一定 ...
- bzoj 4899 记忆的轮廓 题解(概率dp+决策单调性优化)
题目背景 四次死亡轮回后,昴终于到达了贤者之塔,当代贤者夏乌拉一见到昴就上前抱住了昴“师傅!你终于回来了!你有着和师傅一样的魔女的余香,肯定是师傅”.众所周知,大贤者是嫉妒魔女沙提拉的老公,400年前 ...
- 实现同时将一批.bmp文件转换成.mat格式
%% 功能:实现同时对一批.bmp文件的转换成.mat格式PicFormat = {'*.bmp','Bitmap image (*.bmp)';... '*.jpg','JPEG image (*. ...
- 灰度图像--频域滤波 傅里叶变换之连续信号傅里叶变换(FT)
学习DIP第20天 转载请标明本文出处:http://blog.csdn.net/tonyshengtan,欢迎大家转载,发现博客被某些论坛转载后,图像无法正常显示,无法正常表达本人观点,对此表示很不 ...
- sh_20_for语法演练
sh_20_for语法演练 for num in [1, 2, 3]: print(num) if num == 2: break else: # 如果循环体内部使用break退出了循环 # else ...
- Codeforces 979 D. Kuro and GCD and XOR and SUM(异或和,01字典树)
Codeforces 979 D. Kuro and GCD and XOR and SUM 题目大意:有两种操作:①给一个数v,加入数组a中②给出三个数x,k,s:从当前数组a中找出一个数u满足 u ...
- sql把一段时间分割成周,月,季度,年的时间段
--本周 select TO_CHAR(CREATE_DATE ,'yyyy-MM-dd')as NEW_DATE , TO_CHAR(trunc(CREATE_DATE, ,'yyyy-MM-dd' ...