ZCMU 2164 去注释 (字符串操作,读取回车)

本文介绍了一种用于去除C++代码中注释的算法,包括行注释(//)和段落注释(/*...*/)。通过读取字符串并逐行检查,算法能够识别并删除所有类型的注释,同时保留必要的换行符,确保代码格式正确。

Problem I: 去注释

Time Limit: 1 Sec  Memory Limit: 128 MB
Submit: 110  Solved: 45
[Submit][Status][Web Board]

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;

}

 

题目大意:

要求输入一段有注释的代码,将注释去掉后输出。

想法:

本题首先要解决的问题是如何让字符串读入回车,首先我们要定义一个字符串string s,然后用getline(cin,s[k])的方式输入即可。

注释分两种:// 和 /* */,每次碰到‘ / ‘都要判断下一个字符是什么,第一种需要从//到行尾都去掉,第二种需要把从/*到*/都去掉,要注意的是*/之后如果有回车是不能去掉的,这样去除注释以后应该要有一个空行。注意到这个问题再注意一下细节就可以顺利ac了。

AC代码:

#include<bits/stdc++.h>
 
using namespace std;
 
string s[10000];
 
int main(){
    int k = 0;
    while (getline(cin,s[k])){
        k++;
    }
    for (int i = 0; i<k; i++){
        int len = s[i].length();
        for (int 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 (int w = i+1; w<k; w++){
                    int flag = 0;
                    for (int q = 0; q<s[w].length(); q++){
                        if (s[w][q] == '*' && s[w][q+1] == '/'){
                            i += w-i;
                            s[w].erase(0,s[w].length());
                            flag = 1;
                            break;
                        }
                        if (flag == 1){
                            break;
                        }
                    }
                }
            }
        }
        cout<<s[i]<<endl;
    }
    return 0;
}

 

<think>好的,用户想查询ZCMU OJ 1318的题目详情或解题方法。首先,我需要确认自己是否了解这个题目。由于ZCMU OJ的题目可能不在我的训练数据中,我需要根据现有的引用信息进行推断,或者给出一般性的建议。 查看用户提供的引用,发现引用1提到了1614题涉及字符串替换和大小写处理,引用2是1489题关于数气球,引用3是1900题关于并查集的应用。这些信息可能帮助用户解决类似问题,但用户明确询问的是1318题,因此需要处理这个具体的问题。 首先,我需要检查是否有关于1318题的引用,但用户给出的引用中并没有直接提到1318。因此,可能需要建议用户通过题目编号查找或根据常见题型推测。例如,ZCMU的题目可能涉及数据结构、算法或字符串处理等。考虑到引用中的其他题目涉及字符串处理和并查集,1318可能属于类似类型。 接下来,我应该建议用户检查题目链接或提供更多细节,比如题目描述或输入输出样例,以便更准确地分析。同时,可以给出常见的解题思路,比如字符串处理、动态规划或图论算法,并参考现有引用中的类似题目,如字符串处理要注意大小写(引用1),数气球可能涉及计数或哈希表(引用2),并查集用于处理连通性问题(引用3)。 如果用户无法提供更多信息,可以建议搜索ZCMU OJ的在线资源或论坛,比如官方网站、GitHub题解或相关讨论区。此外,提供通用的解题步骤,如分析输入输出、确定算法、处理边界情况等,可能对用户有帮助。 最后,生成相关问题,引导用户进一步提问或提供更多细节,以便更精准地解答。</think>根据现有资料,ZCMU OJ 1318的具体题目内容未在提供的引用中直接提及。以下是帮助您解决此类编程题目的通用方法及建议: ### 常见解题思路(适用于ZCMU OJ题型) 1. **字符串处理** 若涉及字符串操作(如引用[^1]中1614题的替换和大小写处理): ```python # 示例:字符串替换时保留大小写标记 original = "HelloWorld" positions = [0 if c.isupper() else 1 for c in original] # 记录大小写位置 modified = original.lower().replace("world", "Python") result = "".join([c.upper() if positions[i]==0 else c for i,c in enumerate(modified)]) ``` 2. **并查集应用** 若涉及连通性问题(如引用[^3]中1900题的多米诺骨牌): ```python class UnionFind: def __init__(self, n): self.parent = list(range(n+1)) def find(self, x): if self.parent[x] != x: self.parent[x] = self.find(self.parent[x]) return self.parent[x] def union(self, x, y): self.parent[self.find(y)] = self.find(x) ``` 3. **计数与统计** 若涉及数值统计(如引用[^2]中1489题的气球计数): ```python from collections import defaultdict def count_balloons(arr): counter = defaultdict(int) for num in arr: counter[num] += 1 return max(counter.values()) if counter else 0 ``` ### 建议步骤 1. **获取题目描述** 访问ZCMU OJ官网或通过题目编号搜索获取1318题的输入输出样例及具体要求。 2. **分析问题类型** - 若涉及字符串:注意大小写处理、特殊符号过滤 - 若涉及数学:推导公式或使用动态规划 - 若涉及图论:构建邻接表或应用DFS/BFS 3. **参考相似题目** 如引用的字符串替换题需额外记录大小写位置,这种技巧可推广到其他需要保留原始格式的场景。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值