有一个投篮游戏。球场有p个篮筐,编号为0,1...,p-1。每个篮筐下有个袋子,每个袋子最多装一个篮球。有n个篮球,每个球编号x i  。规则是将数字为x i  的篮球投到x i  除p的余数为编号的袋里。若袋里已有篮球则球弹出游戏结束输出i,否则重复至所有球都投完。输出-1。问游戏最终的输出是什么? #include<iostream> #include <set> usingnamespacestd;   //作者 darren_wang intmain() {     intp, n; //篮筐数,篮球数     intx, i;           while(cin >> p >> n){         intflag=0; //作用:1.判断是否有冲突 2.如果有冲突则记录第一个冲突的序号         set<int> myset; //每一批输入样例构造一个空集合         for(i=1; i<=n; i++){ //以1开始,便于这个题目处理             cin >> x;             if(myset.find(x%p)!=myset.end() && !flag) flag = i; //注意输入示例,只记录第一次冲突的,后面再有冲突的并不记录             elsemyset.insert(x%p);         }         if(flag) cout << flag << endl; // 有冲突         elsecout << -1 << endl; // 没有冲突     }     return0; }
点赞 2

相关推荐

雪飒:我也遇见过,我反问他有考虑来华为od吗?
点赞 评论 收藏
分享
牛客网
牛客企业服务