//思路是相同家庭的人存储在动态二维数组后面
//大家可以调试看一下就会明白,调试的时候很简单明了
//因为编者是菜鸟,欢迎大家批评指正
#include
using namespace std;
struct F
{
int a;
int b;
};
int main()
{
F c;
queue
vector
vector<vector
vector<std::vector
int i = 1, n, k,u;
for (p1 = P.begin(); p1 != P.end(); p1++) //二维数组初始化,其实也用不了一百个,p[i]就相当于这个人的序号
for (p2 = p1->begin(); p2 != p1->end(); p2++)
*p2 =i++;
cin >> n >> k;
for (int i = 0; i < k; i++) //入队
{
cin >>c.a >>c.b;
if (c.a < c.b)
{
C.push(c);
D.push(c);
}
else //防止100 3 ,4 3这种情况
{
u = c.a;
c.a = c.b;
c.b = u;
C.push(c);
D.push(c);
}
}
while (!C.empty()) //将队列中家庭进入二维数组找相同
{
int flag = 0; //标记, 操作成功就跳出
int biao = 0;
c = C.front();
for (p1 = P.begin(); p1 != P.end(); p1++)
{
for (p2 = p1->begin(); p2 != p1->end(); p2++)
{
if (*p2 == c.a) //相同即是一家人,就加入该数组后面
{
for (p3 = p1->begin(); p3 != p1->end(); p3++)//避免相同的的数如输入1 2 1 2
{
if (*p3 == c.b)
{
biao++;
break;
}
}
if (biao == 0)
{
p1->push_back(c.b); //加入对应的家庭
P[c.b - 1][0] = -1; //另一个序号对应的家庭赋值为-1
flag = 1;
break;
}
}
/*else if (*p2 == c.b) //为了防止输入100 3,但是前面输入时可以简单解决
{
for (p3 = p1->begin(); p3 != p1->end(); p3++)
{
if (*p3 == c.b)
{
biao++;
break;
}
}
if (biao == 0)
{
p1->push_back(c.a);
P[c.a - 1][0] = -1;
flag = 1;
break;
}
}*/
}
if (flag == 1)break;
}
C.pop(); //出队
}
//不要以下的代码只能拿到百分之八十的分数
//输入
//20 5
//1 7
//2 3
//3 7
//5 6
//7 8
while (!D.empty())
{
int flag = 0;
int biao = 0;
c = D.front();
for (p1 = P.begin(); p1 != P.end(); p1++)
{
for (p2 = p1->begin(); p2 != p1->end(); p2++)
{
if (*p2 == c.a) //相同即是一家人,就加入该数组后面
{
for (p3 = p1->begin(); p3 != p1->end(); p3++) //避免相同的的数
{
if (*p3 == c.b)
{
biao++;
break;
}
}
if (biao == 0)
{
p1->push_back(c.b);
P[c.b - 1][0] = -1;
flag = 1;
break;
}
}
}
if (flag == 1)break;
}
D.pop(); //出队
}
int max = 0;
int len = 0; //长度,来找最大家庭
int fam = 0;
for (p1 = P.begin(); p1 != P.end(); p1++)
{
len = 0;
for (p2 = p1->begin(); p2 != p1->end(); p2++)
{
len++;
}
if (len > max)max = len; //最大家庭人数
}
i = 0;
for (p1 = P.begin();i<n; i++,p1++)
{
for (p2 = p1->begin(); p2 != p1->end(); p2++)
{
if (*p2 != -1)fam++;
break;
}
}
cout << fam<<" " << max;
return 0;
}
0.0分
2 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复