蓝桥杯 算法提高 去注释

  算法提高 去注释  
时间限制:1.0s   内存限制:256.0MB
    
  
  去注释
问题
  给你一段C++代码,将其中的注释去除后输出剩余的代码。
  注释共有两种形式:
  1. 行注视:以//开头,一直作用到行尾为止。
  例子:
  int n; //n表示数据规模
  int a;
  去注释后:
  int n;
  int a;
  注意:保留行尾换行符
  2. 段注视:以/*开头,到*//结尾,中间部分都是注释,可以跨行。
  例子:
  int main() {
  /*
  我是
  一段
  注释
  */
  }
  去注释后:
  int main() {

  }
  注意:由于在线评测系统(Online Judge)对网页显示文本作了格式化,一些空行会被删去,导致上面显示的删除后的结果不正确。删除注释后,剩余的代码应该是三行,两行代码之间有一个空行。这是因为:在段注释结尾符的后面有一个换行符,它不在注释内,需要保留。
输入格式
  一段C++程序代码
输出格式
  去掉注释部分后的程序
样例输入
int main() {
/*
我是
一段
注释
*/
int n;//n表示数据规模
}
样例输出
int main() {

int n;
}

注意:和之前题目中的解释一样,在int n;之前有一个空行,被在线评测系统删掉,实际程序输出应该有该空行。
输入方法
  此题按字符输入,即不断输入下一个字符,直到字符流结束。
  char c;
  C函数方法:
  while ((c = getchar()) != EOF) {
  处理..
  }
  C++流方法:
  while ((c = cin.get()) != EOF) {
  处理..
  }


已经通过测试:100%
#include<iostream>
#include<string>
using namespace std;
int main()
{
	string s[100001];
	int k=0,i=0,j=0,w,q;
	while(getline(cin,s[i])){
		i++;
		k++;
	}
	for(i=0;i<k;i++){
		int len=s[i].length();
		for(j=0;j<len;j++){
			if(s[i][j]=='/'&&s[i][j+1]=='/'){
				s[i].erase(j,len-j);
				break;                  //跳出该次循环 
			}
			if(s[i][j]=='/'&&s[i][j+1]=='*'){
				for( w=i+1;w<k;w++){                  //查找对应的*/           循环 1 
					int flag=0;
					for(q=0;q<s[w].length();q++)                           //循环   2 
					if(s[w][q]=='*'&&s[w][q+1]=='/')            
					{
						i+=w-i;
						s[w].erase(0,s[w].length());
						flag=1;                     //标记是否找到*/,如果找到,flag=1; 
						break;                     //跳出内层循环  2
					}
					if(flag==1)		
					break;                         //对应于flag,跳出 循环  2
				}
			}
		}
		cout <<s[i]<<endl;
	}
	return 0;
}


  • 0
    点赞
  • 0
    收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:像素格子 设计师:CSDN官方博客 返回首页
评论

打赏作者

AC_木子

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值