zoukankan      html  css  js  c++  java
  • 算法提高 去注释

    算法提高 去注释
     

    Description

      去注释

    Input

     

    输入描述:

      给你一段C++代码,将其中的注释去除后输出剩余的代码。

      注释共有两种形式:

      1. 行注视:以//开头,一直作用到行尾为止。

      例子:

      int n;//n表示数据规模

      int a;

      去注释后:

      int n;

      int a;

      注意:保留行尾换行符

      2. 段注视:以/*开头,到*//结尾,中间部分都是注释,可以跨行。

      例子:

      int main() {

      /*

      我是

      一段

      注释

      */

      }

      去注释后:

      int main() {

      }

      注意:由于在线评测系统(Online Judge)对网页显示文本作了格式化,一些空行会被删去,导致上面显示的删除后的结果不正确。删除注释后,剩余的代码应该是三行,两行代码之间有一个空行。这是因为:在段注释结尾符的后面有一个换行符,它不在注释内,需要保留。

    输入样例:

    int main() {

    /*

    我是

    一段

    注释

    */

    int n;//n表示数据规模

    }

    Output

     

    输出描述:

      一段C++程序代码

    输出样例:

    int main() {

    int n;

    }

    注意:和之前题目中的解释一样,在int n;之前有一个空行,被在线评测系统删掉,实际程序输出应该有该空行。

    C++ 流方法:

    cin.get() 的作用相当于c里面的getchar可以读取不可见字符,包括空格和回车

    while((c=cin.get()) != EOF) 判断是否读到了末尾元素

    根据读到的字符是什么,分别进入不同的分支

    #include <iostream>
    #include <cstring>
    #include <algorithm>
    #include <cmath>
    
    using namespace std ;
    
    char arr[1000010] ;
    
    int main(){
        
        char c,c1,c2 ;
        while((c1=cin.get()) != EOF){
            if(c1 == '/'){
                c2 = cin.get() ;
                if(c2 == '/'){
                    while((c = cin.get())!= '
    '){
                        if(c == EOF) return 0 ;
                    }
                    cout << c ;            
                }else if(c2 == '*'){
                    int len = 0 ;
                    while(true){
                        if((c = cin.get()) != EOF){
                            arr[len++] = c ;
                            if(c == '/'){
                                if(len>=2 && arr[len-2] == '*'){
                                    break ;
                                }
                            }
                        }
                    }
                }else{
                    cout << c1 << c2 ;
                }
            }else{
                cout << c1 ;
            }
        }
    
        return 0 ;
    }

    ...

  • 相关阅读:
    【CSP模拟赛】益智游戏(最短路(DJSPFA)&拓扑排序)
    【CSP模拟赛】仔细的检查(树的重心&树hash)
    【CSP模拟赛】奇怪的队列(树状数组 &二分&贪心)
    【洛谷】P1275 魔板(暴力&思维)
    【CSP模拟赛】方程(数学)
    【洛谷】P3177 [HAOI2015]树上染色
    【洛谷】P3188 [HNOI2007]梦幻岛宝珠
    方法重载(一)
    找最大值
    java 冒泡排序
  • 原文地址:https://www.cnblogs.com/gulangyuzzz/p/12381803.html
Copyright © 2011-2022 走看看