L1-059 敲笨钟
昨天的学习中认识到了string,今天找了道题作为练习
输入格式:
输入首先在第一行给出一个不超过 20 的正整数 N。随后 N 行,每行用汉语拼音给出一句古诗词,分上下两半句,用逗号 , 分隔,句号 . 结尾。相邻两字的拼音之间用一个空格分隔。题目保证每个字的拼音不超过 6 个字符,每行字符的总长度不超过 100,并且下半句诗至少有 3 个字。
输出格式:
对每一行诗句,判断其是否压“ong”韵。即上下两句末尾的字都是“ong”结尾。如果是压此韵的,就按题面方法糟改之后输出,输出格式同输入;否则输出 Skipped,即跳过此句。
输入样例:
5
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;
cin.ignore();//清除换行符
while(n--){
string s,flag,ss;
getline(cin,s);//无空格可用cin,有空格用这个
int a[50];
string::size_type position1,position2,p1,p2,position;
position1=s.find(',');
position2=s.find('.');
p1=s.find("ong",position1-3);
p2=s.find("ong",position2-3);
//判断每句结尾是否为"ong"
if(position1>=3&&p1==(position1-3)&&p2==(position2-3)){
flag=" ";
position=0;
int i=0;
//寻找后半句每个空格的位置,存入数组a
while((position=s.find(flag,position))!=string::npos)
{
a[i]=position;
position++;
i++;
}
ss=s.erase(a[i-3],s.length());
ss.insert(a[i-3]," qiao ben zhong.");
cout<<ss<<endl;
}
else{
cout<<"Skipped"<<endl;
}
}
}
总结
1.在同时使用cin和getline()时,要注意换行符的问题,用cin.ignore()解决
2.今日学习到的方法
insert()//用于插入字符串
assign(string str,int index,int length)//从str中的下标为index开始的length个元素赋值给另一个对象
append()//在字符串的尾部添加字符串
push_back()//在字符串的尾部添加一个字符
clear()//清空字符串
compare()//比较两个字符串,相同则值为1
size(),length()//返回值均为字符串的长度
find()//寻找字符或字符串的位置,返回值为size_type
erase()删除指定位置的字符