中文题目不多说了
思路 直接模拟即可 分情况讨论
代码:
#include<algorithm>
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<cmath>
#include<queue>
#define ll long long
#define inf 0x3f3f3f3f
#define sd(a) scanf("%d",&a)
#define sdd(a,b) scanf("%d%d",&a,&b)
#define cl(a,b) memset(a,b,sizeof(a))
#define rep(i,a,n) for(int i=a;i<=n;i++)
#define sddd(a,b,c) scanf("%d%d%d",&a,&b,&c)
#define dbg() printf("aaa\n")
using namespace std;
int main() {
char ch,la='1';
bool flag1=false;
bool flag2=false;//段注释
while((ch=getchar())!=EOF){
if(flag1){
while(ch!='\n') ch=getchar();
flag1=false;
putchar('\n');
}else if(flag2){//若是段注释
while(la!='*'||ch!='/'){//这你没用好!!换了就a了!!!
la=ch;
ch=getchar();
}
la='1';
flag2=false;
}else{//若当前不是注释
if(ch=='/'){//行注释
char tp=getchar();
if(tp=='/'){//行注释
flag1=true;
}else if(tp=='*'){//段注释
flag2=true;
la='1';
}else{
putchar(ch);
putchar(tp);
}
}else{
putchar(ch);
}
}
}
return 0;
}
给你一段C++代码,将其中的注释去除后输出剩余的代码。
注释共有两种形式:
- 行注视:以//开头,一直作用到行尾为止。
例子:
int n;//n表示数据规模
int a;
去注释后:
int n;
int a;
注意:保留行尾换行符 - 段注视:以/开头,到//结尾,中间部分都是注释,可以跨行。
例子:
int main() {
/*
我是
一段
注释
*/
}
去注释后:
int main() {
}
注意:由于在线评测系统(Online Judge)对网页显示文本作了格式化,一些空行会被删去,导致上面显示的删除后的结果不正确。删除注释后,剩余的代码应该是三行,两行代码之间有一个空 行。这是因为:在段注释结尾符的后面有一个换行符,它不在注释内,需要保留。
样例注意:和之前题目中的解释一样,在int n;之前有一个空行,被在线评测系统删掉,实际程序输出应该有该空行。
输入方法
此题按字符输入,即不断输入下一个字符,直到字符流结束。
char c;
C函数方法:
while ((c = getchar()) != EOF) {
处理…
}
C++流方法:
while ((c = cin.get()) != EOF) {
处理…
}
输入
一段C++程序代码
输出
去掉注释部分后的程序
样例输入
int main() {
/*
我是
一段
注释
*/
int n;//n表示数据规模
}
样例输出
int main() {
int n;
}