PTA乙级1069,微博转发抽奖

方法1(用集合set处理):注意那个while循环是防止出现连续多个相同字符串的情况,所以不能用if条件语句

#include<bits/stdc++.h>
using namespace std;

int main(){
    int M,N,S;
    scanf("%d%d%d",&M,&N,&S);
    vector<string>v(M+1);//存储输入的字符串

    for(int i=1;i<=M;i++){
        cin>>v[i];
    }
    set<string>s;//保存已中奖的字符串
    
    for(int i=S;i<=M;i+=N){
        while(i<=M&&s.find(v[i])!=s.end())//不能用if语句,防止后面几个都是已经中奖过的
            i++;
        if(i<=M){
            cout<<v[i]<<endl;
            s.insert(v[i]);
        }
    }

    if(s.empty())
        cout<<"Keep going..."<<endl;
    return 0;
}

方法2(用映射map处理)

#include<bits/stdc++.h>
using namespace std;

int main(){
    int m,n,s;
    bool flag=false;//标志变量,用于判断最后是否有中奖的
    cin>>m>>n>>s;

    string str;
    map<string,int> a;//存储已经中奖过的字符串

    for(int i=1;i<=m;i++){
        cin>>str;//输入字符串信息

        if(a[str]==1)
            s=s+1;//如果当前字符串已中奖过,则跳至下一个

        if(i==s&&a[str]==0){
            a[str]=1;//映射中为1表示已中奖过
            cout<<str<<endl;
            flag=true;
            s+=n;//应该中奖的索引进行更新
        }
    }

    if(flag==false)
        cout<<"Keep going...";

    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值