poj 2367 Genealogical tree (拓扑排序)-程序员宅基地

火星人的血缘关系很奇怪,一个人可以有很多父亲,当然一个人也可以有很多孩子。
有些时候分不清辈分会产生一些尴尬。所以写个程序来让n个人排序,长辈排在晚辈前面。

输入:N 代表n个人 1~n 接下来n行 第i行表示第i个人的孩纸,无序排列,可能为空。0代表一行输入结束。

(大概我的智商真的不合适,否则怎么这么久了连个拓扑排序都写不好,T了三次。。)

代码:

/********************************************
Problem: 2367		User:
Memory: 700K		Time: 32MS
Language: G++		Result: Accepted
********************************************/
#include <iostream>
#include <cstdio>
#include <cstring>
#include <vector>

using namespace std;

const int N = 105;
int n;
vector<int> G[N];
int RD[N];
int vis[N];

void topsort()
{
	for (int j = 1; j <= n; ++j)
		for (int i = 1; i <= n; ++i) {
			if (!vis[i] && RD[i] == 0) {

				if (j != 1) printf(" ");
				printf("%d", i);
				for (int k = 0; k < G[i].size(); ++k)
					--RD[G[i][k]];
				vis[i] = 1;
				break;
			}
		}
	printf("\n");
}

int main()
{
	scanf("%d", &n);
	for (int i = 1; i <= n; ++i) {
		int temp;
		while (scanf("%d", &temp) == 1) {
			if (temp == 0) break;
			G[i].push_back(temp);
			++RD[temp];
		}
	}
	topsort();
    return 0;
}

  

好吧,改了一下第一次的代码也A了,输入的问题= =#

/****************************************
Problem: 2367		User: 
Memory: 736K		Time: 0MS
Language: G++		Result: Accepted
****************************************/
#include <iostream>
#include <cstdio>
#include <cstring>
#include <vector>

using namespace std;

const int N = 105;

int mp[N][N]; // mp[i][j] i is j's son
int vis[N];
int n;

void read(int i)
{
	char ch;
	int ans = 0;
	
	while (scanf("%d", &ch), ch) {
		mp[ch][i] = 1;
		++mp[ch][0];
	}
}

void tpsort()
{
	int i, j;
	for (j = 1; j <= n; ++j) {
		for (i = 1; i <= n; ++i) {
			if (!vis[i] && mp[i][0] == 0) {
				if (j != 1) printf(" ");
				printf("%d", i);
				vis[i] = 1;

				for (int k = 1; k <= n; ++k) {
					if (!vis[k] && mp[k][i] == 1) {
						mp[k][i] = 0;
						--mp[k][0];
					}
				}
				break;
			}
		}
	}
	printf("\n");
}

int main()
{
    scanf("%d", &n);
	getchar();
	memset(mp, 0, sizeof mp);
	memset(vis, 0, sizeof vis);
	for (int i = 1; i <= n; ++i) {
		read(i);
	}
	tpsort();
    return 0;
}

  

转载于:https://www.cnblogs.com/wenruo/p/4719203.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_30267697/article/details/95787740

智能推荐

基于 python 的主成分分析步骤及应用实例-程序员宅基地

文章浏览阅读3.6k次。主成分分析:步骤、应用及代码实现。主成分分析(Principal Component Analysis)算法步骤:设有 m 条 n 维数据:将原始数据按列组成 n 行 m 列矩阵 X将 X 的每一行(代表一个属性字段)进行零均值化,即减去这一行的均值求出协方差矩阵 C=1mXXTC=\frac{1}{m}XX^{T}C=m1​XXT求出协方差矩阵的特征值及对应的特征向量将特征向量按...

项目管理课程笔记_单引号 项目管理-程序员宅基地

文章浏览阅读126次。项目管理课程笔记第一节1.``代码高亮``2.标题设立3.列表4.粗体与斜体5.链接和图片6.分割线7.表格第一节1.代码高亮在代码的左侧和右侧分别写上两个反单引号,提高代码亮度。2.标题设立在Markdown中为设立标题只需井号后加空格即可(井号数量对应标题级别)。3.列表在文字前加上减号即可设置列表,若是有序列表则将减号改为数字和点即可。4.粗体与斜体单个星型标示符(小键盘中的乘号)即为斜体,两个则是粗体,将其按需求写在文字前后即可。5.链接和图片在Markdown中插入图_单引号 项目管理

mvn dependency:tree的用法_maventree-程序员宅基地

文章浏览阅读4k次。mvn dependency:tree的用法一.参考文档https://maven.apache.org/plugins/maven-dependency-plugin/examples/resolving-conflicts-using-the-dependency-tree.htmlhttps://maven.apache.org/plugins/maven-dependency-..._maventree

EF更新使用AutoMapper_se7en3_新浪博客-程序员宅基地

文章浏览阅读147次。EF更新使用AutoMapper,vardbEntity=Mapper.Mapper(viewModel)这样写,有可能保存之后没有异常,但是数据库数据没有更新。应该Mapper.Mapper(viewModel,entityModel)。 ..._ef automapper 更新

Hadoop Snappy安装终极教程_an ant buildexception has occured: snappy native l-程序员宅基地

文章浏览阅读6.6k次,点赞2次,收藏4次。原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://shitouer.cn/2013/01/hadoop-hbase-snappy-setup-final-tutorial/ 因为产品需要,这两天研究了一下Hadoop Snappy。先不说什么各个压缩算法之间的性能对比,单是这个安装过程,就很痛苦。网上有很多博友写H_an ant buildexception has occured: snappy native library not found at /usr/l

PPT | Docker定义存储-让应用无痛运行-程序员宅基地

文章浏览阅读55次。为什么80%的码农都做不了架构师?>>> ...

随便推点

程序员薪资两极分化,如何成为高薪程序员?-程序员宅基地

文章浏览阅读1k次。整理 | 李磊出品 | CSDN(ID:CSDNnews)现代管理学之父彼得·德鲁克在《知识社会》中说,40 年前,从事知识与服务劳动的人占总劳动力的比例不到 1/3。今天的发达国家,这一..._程序员两极分化

离散型随机变量的常见概率分布-程序员宅基地

文章浏览阅读7.8k次。伯努利0-1分布事件A在某次试验中发生的概率稳定计为pp,但A要么发生要么不发生,随机变量XX,单次试验中A发生记为1,没有发生记为0,则P(X=1)=p,P(X=0)=1−pP(X=1)=p,P(X=0)=1-p,也可以统一成这个公式: f(x|p)=px(1−p)1−x,x=0,1f(x|p)=p^x(1-p)^{1-x},x=0,1期望 方差期望:E(X)=∑x∗p(x)=

android camera2拍照图像输出过慢,华为手机比较明显_android优化camera拍照速度-程序员宅基地

文章浏览阅读1.3k次。最近在camera2自定义相机拍照,在点击拍照按钮回调,在处理图像流的时候总是卡主尤其是华为手机,几乎所有手机都会拍照后拿不到imageReader读取的image然后我加了个300ms的延迟后,可以成功读取到完整的图像流了,但是体验感很不好在测试以后 ,发现华为手机在将图像流处理为jpeg的时候,需要243ms。这是造成卡主的原因,也解释了我加了300ms以后就不卡主的原因 原始代码val captureCallback = object : CameraCaptureSessi.._android优化camera拍照速度

腾讯x5在线打开pdf遇到的一些问题_tbsreaderview过时-程序员宅基地

文章浏览阅读6.6k次。1.在使用 QbSdk ,还是选择 TbsReaderView使用Qbsdk int i = QbSdk.openFileReader(context, filePath, null, new ValueCallback&lt;String&gt;() { @Override public void onReceiveValue(String s) { KLog.d(..._tbsreaderview过时

实体互转-程序员宅基地

文章浏览阅读82次。public class ConvertHelper { public static List<T2> ConvertToList<T1, T2>(List<T1> source) { List<T2> t2List = new List<T2>(); if (..._t2 model = default(t2);

MVC 强类型传值Model。和弱类型传值ViewData[&quot;&quot;]。及用EF进行增删查改(母版页的使用)...-程序员宅基地

文章浏览阅读147次。&lt;1&gt;控制器&lt;/pre&gt;&lt;pre name="code" class="csharp"&gt;using MvcTest.Models;using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Web.Mvc;..._mvc怎么使用强类型ienumerable实现添加数据