title: ZCMU2164 去注释(string应用) date: 2018-07-31 17:29:31 tags: [ZCMU,STL,算法] categories: 算法
ZCMU2164 去注释(string应用)
Description
给你一段C++代码,将其中的注释去除后输出剩余的代码。注释共有两种形式:\1. 行注视:以//开头,一直作用到行尾为止。例子:int n;//n表示数据规模int a;去注释后:int n;int a;注意:保留行尾换行符\2. 段注视:以/开头,到//结尾,中间部分都是注释,可以跨行。例子:int main() {/*我是一段注释*/}去注释后:int main() {
}注意:由于在线评测系统(Online Judge)对网页显示文本作了格式化,一些空行会被删去,导致上面显示的删除后的结果不正确。删除注释后,剩余的代码应该是三行,两行代码之间有一个空 行。这是因为:在段注释结尾符的后面有一个换行符,它不在注释内,需要保留。
Input
一段C++程序代码
Output
去掉注释部分后的程序
Sample Input
int main() { /* 我是 一段 注释 */ int n;//n表示数据规模 }
Sample Output
int main() { int n; }
思路
有许多方法可以处理这类字符串问题,有用getchar()一个一个处理的,我是用getline(cin,s)把每一行存入string型变量s中,再判断处理并输出,具体操作看代码及注释
关键函数:
find()
str.find(str2), 当str2是str的子串时,返回其在str中第一次出现的位置;如果str2不是str的字串,那么返回string::npos ,
erase()
erase()其中一种用法:删除一个区间内的所有元素,区间可以用迭代器表示也可以用位置表示,本题中用来删除注释。
注意
getline()遇到回车结束,并不会读取回车,因此输出时要手动加回车。
代码
#include<bits/stdc++.h>
using namespace std;
string s;
int main()
{
//freopen("fopen.txt","r",stdin);
while(getline(cin,s))//不断读入行
{
if(s.find("//")==string::npos && s.find("/*")==string::npos)//如果这行没有注释
cout<<s<<endl;//直接输出
else if(s.find("//")!=string::npos)//如果有行注释
{
s.erase(s.find("//"),s.length()-s.find("//"));//删除行注释
cout<<s<<endl;//输出并手动加上换行
}
else if(s.find("/*")!=string::npos)//如果是段注释的开始
{
while(1)
{
getline(cin,s);//不断"吃掉注释"内容和最后的*/
if(s.find("*/")!=string::npos)
{
cout<<endl;//手动换行
break;
}
}
}
}
return 0;
}