2025年5.点球大战

5.点球大战问题描述 在足球比赛中 有不少赛事 例如世界杯淘汰赛和欧洲冠军联赛淘汰赛中 当比赛双方经过正规比赛和加时赛之后仍然不分胜负时 需要进行点球大战来决定谁能够获得最终的胜利 点球大战的规则非常简单 两方轮流派出球员罚点球 每方各罚 5 个 当 5 轮点球结束以后如果仍然不分胜负 则进入一轮定胜负的阶段

大家好,我是讯享网,很高兴认识大家。

【问题描述】在足球比赛中,有不少赛事,例如世界杯淘汰赛和欧洲冠军联赛淘汰赛中,当比赛双方经过正规比赛和加时赛之后仍然不分胜负时,需要进行点球大战来决定谁能够获得最终的胜利。点球大战的规则非常简单,两方轮流派出球员罚点球,每方各罚5个。当5轮点球结束以后如果仍然不分胜负,则进入一轮定胜负的阶段。两方各派一名球员罚点球,直到有一方罚进而另一方没有进为止。 
在北美职业冰球联赛中,也有点球大战。与足球的规则不同的是,它只先罚3轮点球,随后就进入一轮定胜负的阶段,而其他的规则完全一样。 
在本题中,输入将给出每次点球是否罚进,而你的任务则是输出一个“比分板”。

【输入形式】输入包含多组数据。每组数据的第一行包含一个整数N(1<=N<=18),表示双方总共罚了多少个点球,N=0表示输入结束。随后有N行,每行是一个如下形式的字符串: 
XXXX good:表示这个点球罚进 
或者XXXX no good:表示这个点球没有罚进 
其中XXXX表示球员名字(全部由字母和空格组成,保证不会出现歧义) 
每一行保证不超过100个字符。 
XXXX和good以及XXXX和no、no和good之间保证有且只有1个空格。 
good、no good都是小写。本题是大小写相关的。 
数据不保证点球大战一定结束,也不保证在结束以后立即结束这组数据(即:不用判断点球大战是否结束,只用把罚进的点球往比分上加即可)。

【输出形式】对每组数据,输出一个比分板。一个点球如果罚进,则在对应的地方标上’O’,如果没有进则标上’X’。先罚球的队伍的信息在上面,后罚的在下面。最右边标上两队的比分。具体格式参考样例输出。注意如果一轮点球只罚了一个,则后面那个点球对应的地方写上’-’。

【样例输入】


讯享网

6
Riise good
Ballack good
Gerrard no good
Lampard no good
Fernando Torres good
Malouda good
9
Christiano Ronaldo no good
Messi no good
Giggs good
Abidal no good
Carrick good
Ronaldinho good
Rooney good
Henry no good
Tevez good
0

【样例输出】

1 2 3 Score
O X O 2
O X O 2
1 2 3 4 5 Score
X O O O O 4
X X O X - 1

#include<bits/stdc++.h> using namespace std; int main() { int n; while(cin>>n&&n!=0) { int m; if(n%2==0) m=n/2; else m=(n+1)/2; char arr[2][m]; //0表示先罚球的队伍 1为后罚球的队伍 memset(arr,'-',sizeof(arr));//初始化 cin.get(); for(int i=0,j=0,k=0; i<m||j<m;) { //大循环进行点球 string str; if(n%2==1) {//n的奇偶性不同,跳出循环条件不同 if(i>=m)break; } getline(cin,str);//将一行读入 int lenstr; lenstr=str.size();//一行的长度 string key="no good";//长度为7 string key1=str.substr(lenstr-7,7);//将最后长度7的字符截取出来,进行比较。判断是否进球 char ckey; if(key==key1) ckey='X'; //没进球 else ckey='O';//当前球员进球 if(k%2==0) { //第一个队 arr[0][i]=ckey; i++; k++; } else if(k%2==1) { //第二个队 arr[1][j]=ckey; j++; k++; }//以上的if-else语句将各队的胜负情况记录 } //下边代码进行格式化输出 for(int i=1; i<=m; i++) cout<<i<<' '; cout<<"Score"<<endl; int sum1=0; int sum2=0; for(int i=0; i<m; i++) { if(arr[0][i]=='O')sum1++; if(arr[1][i]=='O')sum2++; } for(int i=0; i<m; i++) cout<<arr[0][i]<<' '; cout<<sum1<<endl; for(int i=0; i<m; i++) cout<<arr[1][i]<<' '; cout<<sum2<<endl; } return 0; }

讯享网

小讯
上一篇 2025-03-07 17:03
下一篇 2025-02-28 15:07

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/11542.html