ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

L - Who is the Champion

2021-05-22 13:58:29  阅读:201  来源: 互联网

标签:200 return Champion int Who else k1 printf


L - Who is the Champion 计蒜客 - 42587

题意:

给出一个N阶矩阵,( i , j ) (i, j)(i,j)处的数字表示这场比赛球队i ii踢进球队j jj多少球。两支球队平局则各加一分,一方获胜则获胜方加三分,负方不加分也不扣分。输出冠军队编号。优先比较分数,分数一样的话比较胜场数,胜场数一样的话输出play-offs。

题解:

队友写的。。
定义一个结构体,然后按照题目算分,排序就完事了

代码:

#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
int a[200][200];
struct h{
	int k;
	int k1;
	int id;
	int w;
};
h k[200];
bool cmp(h a,h b){
	if(a.w==b.w){
		return (a.k-a.k1)>(b.k-b.k1);
	}
	else
		return a.w>b.w;
}

int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++){
		k[i].id=i;
		for(int j=1;j<=n;j++){
			cin>>a[i][j];
			k[i].k+=a[i][j];
		}
	}
	if(n==1){
		printf("1");
		return 0;
	}
	for(int j=1;j<=n;j++){
		for(int i=1;i<=n;i++){
			k[j].k1+=a[i][j];
		}
	}
	for(int i=1;i<=n;i++){
		for(int j=i+1;j<=n;j++){
			if(a[i][j]>a[j][i]){
				k[i].w+=3;
			}
			else if(a[i][j]==a[j][i]){
				k[i].w++;
				k[j].w++;
			}
			else{
				k[j].w+=3;
			}
		}	
	}
	sort(k+1,k+1+n,cmp);

	if(k[1].w==k[2].w&&k[1].k-k[1].k1==k[2].k-k[2].k1){
		printf("play-offs");
	}
	else
		printf("%d",k[1].id);
	return 0;
}

标签:200,return,Champion,int,Who,else,k1,printf
来源: https://blog.csdn.net/qq_35975367/article/details/117158580

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有