中文題目不多說了
思路 直接模擬即可 分情況討論
代碼:
#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;
}