题解:P10678 『STA - R6』月

P10678 『STA - R6』月 题解

题目简述:

给定一棵 n n n 个节点的树,每个节点的度数 d i d_i di,请你构造一棵树,使数的深度尽可能小。

大致思路:

显而易见的,根据类似贪心的思路,显然要先处理度数大的,让他们尽可能向上靠,也就是用一个结构体存,接着,根据 d i d_i di 从大到小进行排序,进行遍历,用广度优先搜索,将边依依填如,在填中,输出相应连接边的点。要注意的是,由于根没有父节点,我们是从上往下搭建的,因此,在将它放入时,要将它深度加上 1 1 1,以此类推,根据它的深度,来判断插入边的数量,总体复杂度 O ( n log ⁡ n ) O(n \log n) O(nlogn),可以通过。

代码实现:

#include<bits/stdc++.h>
using namespace std; 
const int N = 3e5 + 10;
struct node
{
	int d, id, cnt;
}a[N];
int T, n;
bool cmp(node l, node r)
{
	return l.d > r.d;
}
void bfs()
{
	queue < node > q;
	a[1].d ++;//根节点无父亲 
	int tp = 1;
	q.push(a[1]);//将认定的根放进去 
	while(q.size())
	{
		node x = q.front();
		q.pop();
		for(int i = 1;i < x.d; ++ i)
		{
        	q.push(a[++ tp]); 
			cout << x.id << " " << a[tp].id << "\n";
		}
	}
}
signed main(){
	cin >> T;
	while (T --)
	{
		cin >> n;
		for (int i = 1;i <= n; ++ i)
		{
			cin >> a[i].d;
			a[i].id = i;
		}
		sort(a + 1, a + n + 1, cmp);
		bfs();
	}
	return 0;
}

这样这道题就完成啦!!!

相关推荐

  1. 题解P10678STA - R6

    2024-07-16 19:36:02       17 阅读
  2. UVA10678 The Grazing Cow 题解a

    2024-07-16 19:36:02       45 阅读
  3. P6492 [COCI2010-2011#6] STEP 题解

    2024-07-16 19:36:02       40 阅读
  4. P1068 [NOIP2009 普及组] 分数线划定 Python

    2024-07-16 19:36:02       40 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-16 19:36:02       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-16 19:36:02       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-16 19:36:02       58 阅读
  4. Python语言-面向对象

    2024-07-16 19:36:02       69 阅读

热门阅读

  1. 每天一个数据分析题(四百三十)- 假设检验

    2024-07-16 19:36:02       19 阅读
  2. 【PG】PostgreSQL高可用之repmgr命令手册

    2024-07-16 19:36:02       21 阅读
  3. GPT带我学-设计模式14-工厂模式

    2024-07-16 19:36:02       18 阅读
  4. InnoDB

    2024-07-16 19:36:02       21 阅读
  5. 跨入嵌入式day1(Linux下C语言-基础知识)

    2024-07-16 19:36:02       18 阅读
  6. sqlalchemy mapper的使用

    2024-07-16 19:36:02       17 阅读
  7. git初始化项目

    2024-07-16 19:36:02       18 阅读
  8. 有用的C语言相关函数

    2024-07-16 19:36:02       18 阅读
  9. P10781 【MX-J1-T1】『FLA - III』Spectral 题解

    2024-07-16 19:36:02       16 阅读
  10. docker镜像源配置

    2024-07-16 19:36:02       19 阅读
  11. React基础学习-Day05

    2024-07-16 19:36:02       17 阅读