勇子的


私信TA

用户名:HelloWorld123

访问量:1945

签 名:

等  级
排  名 8938
经  验 1193
参赛次数 0
文章发表 3
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

解题思路:我是刚开始用字符串做的,交上去一直WA,但是在蓝桥杯官网上提交是可以AC的。无奈只能换一种方法了。换的方法:不再读取字符串,而是直接读取整数,以EOF结束,竟然AC了。。。
注意事项:

参考代码:

在蓝桥杯官网上可以AC的代码:

#include<bits/stdc++.h>
#include<cstdio>
using namespace std;
int main()
{
    int n;
    vector<int> S;
    cin>>n;
    cin.get();
    for(int i=0;i<n;i++){
        string s;
        getline(cin,s);
        for(int j=0;j<s.length();j++){
            if(s[j]>='0'&&s[j]<='9'){
                int sum = 0;
                while((s[j]>='0'&&s[j]<='9')&&(j<s.length())){
                    sum = sum*10+s[j]-'0';
                    j++;
                }
                S.push_back(sum);
            }
        }
    }
    sort(S.begin(),S.end());
    int flag = 0;
    int a=0,b=0;
    for(int i=1;i<S.size();i++){
        if(S[i]-S[i-1]==2){
            a = S[i]-1;
        }
        if(S[i]==S[i-1]){
            b = S[i];
        }
    }
    cout<<a<<' '<<b<<endl;
    return 0;
}

修改的代码:

#include<bits/stdc++.h>
#include<cstdio>
using namespace std;
int main()
{
    int n;
    vector<int> S;
    cin>>n;
    int data;
    while(cin>>data){
        S.push_back(data);
    }
    sort(S.begin(),S.end());
    int a=0,b=0;
    for(int i=1;i<S.size();i++){
        if(S[i]-S[i-1]==2){
            a = S[i]-1;
        }
        if(S[i]==S[i-1]){
            b = S[i];
        }
    }
    cout<<a<<' '<<b<<endl;
    return 0;
}


 

0.0分

0 人评分

  评论区

  • «
  • »