朋友(friend)

朋友(friend)

题目描述

 经过六年的努力,小明终于被一所知名中学录取。优秀的小明总是对一些奇奇怪怪的事情感
 兴趣,这次他想知道谁在这所新学校拥有的朋友最多,由于大家都才刚报到,所以小明只知
 道大家两两之间是否是朋友关系。

输入

 输入文件friend.in的第一行有两个整数n和m,n表示总人数,m表示总关系数。
接下来m行,每行有2个以空格隔开的整数a和b,表示a和b是朋友,a和b均为1到n之间的整      
数。不会给出重复的朋友关系。

输出

输出文件friend.out中仅有一行,表示朋友数最多的人所拥有的朋友,每两个整数之间用空格
隔开,按照字典序从小到大输出。如果存在多个人朋友数都是最多的情况,请输出字典序最小
的那人的答案,具体见样例。

样例输入

3 3
1 2
2 3
1 3

样例输出

2 3

数据范围限制

50%的数据,1 <= n <= 10
80%的数据,1 <= n <= 1000
100%的数据,1 <= n <= 10000,m <= 500000

提示

1、2、3均拥有2个朋友,因此输出字典序较小的1的朋友即可。
1的朋友为2和3,按照字典序从小到大输出,数字之间用空格隔开。

这道其实很简单,但是可能对于学习了有几年的大佬来说,那就困难了!

what?

没错,一看到这道题,大佬们一般都会选择开个二维数组来判断两个人是否是朋友!问题就出在这,如果这样,一定会空间超限!

那该怎么做?

easy,一开始你边输入边记录拥有最多的人的编号和有多少个,接着用for循环遍历每一对a【i】,b[i],然后判断是否有函这个人,有的话存一个新数组,一边sort,然后输出

code:

#include <algorithm>
#include <iostream>
#include <cstdio>
#include <cmath>
using namespace std;
int n,m,a[500005],b[500005],k,m1,f[10005],c[10005];
int main()
{
	freopen("friend.in","r",stdin);
	freopen("friend.out","w",stdout);
	cin>>n>>m;
	for (int i=1;i<=m;i++)
	{
		cin>>a[i]>>b[i];
		f[a[i]]++;
		f[b[i]]++;
		if (f[a[i]]>m1&&f[a[i]]>f[b[i]]) {m1=f[a[i]];k=a[i];}
		if (f[b[i]]>m1&&f[b[i]]>f[a[i]]) {m1=f[b[i]];k=b[i];}
		if (f[a[i]]==m1) k=min(k,a[i]);
		if (f[b[i]]==m1) k=min(k,b[i]);
	}
	//cout<<k<<endl;
	int t=0;
	for (int i=1;i<=m;i++)
	{
		if(a[i]==k) c[++t]=b[i];
		if(b[i]==k) c[++t]=a[i];
	}
	sort(c+1,c+t+1);
	for(int i=1;i<=t;i++) cout<<c[i]<<' ';
	return 0;
}

谢谢

发布了80 篇原创文章 · 获赞 58 · 访问量 2520

猜你喜欢

转载自blog.csdn.net/bigwinner888/article/details/104540049