目录
题目名称:蚂蚁家族
时间限制:1000ms内存限制:256M
题目描述
小蚂蚁群是一个庞大的群体,在这个蚂蚁群中有n只小蚂蚁 ,为了保证所有蚂蚁在消息传送的时候都能接收到消息,需要在他们之间建立通信关系。就是要求小蚂蚁都可以通过多只或者直接联系到其他人。 已知几条小蚂蚁之间有通信关系,请问还需要再新建至少多少条关系?
输入描述:
第一行输入整数n,m;n为小蚂蚁总数;m为关系数。(1<=n,m<=1000) 以下m行每行m对整数x,y。(代表x与y有联系)
输出描述:
输出最少需要新建关系数。
示例
示例1
输入
4 3
1 2
2 3
3 4复制
输出0复制
提示
数据点的编号都是从小到大,即出发节点小,终到节点编号大;
每只蚂蚁的通信对象的输出端均仅有1个节点,即只有一个子节点,如1->2,2->3;
实现代码:
#输入n为蚂蚁总数;m为已知关系数
n, m = map(int, input().split())
#link为去重后的连接数量
link= set()
#输入已知的关系数,每只蚂蚁的通信对象的输出端均仅有1个节点
# 输入一对(空格做间隔)执行一次循环,提取输入节点[0]即可,
# 要实现完整的通信,则输入节点还需去重(采用加入集合的方法去重)
for i in range(m):
num=int(input().split()[0])
link.add(num)
#起点的蚂蚁无输入端,仅输出,非双向节点,故-1,
#则需要补充的关系数为:小蚂蚁总数-非重复关系数量-1
print(n-len(link)-1)
PS:SET()
描述
set() 函数创建一个无序不重复元素集,可进行关系测试,删除重复数据,还可以计算交集、差集、并集等。
语法
set 语法:
class set([iterable])
参数说明:
- iterable -- 可迭代对象对象;
返回值
返回新的集合对象。
实例
以下实例展示了 set 的使用方法:
>>>x = set('runoob') >>> y = set('google') >>> x, y (set(['b', 'r', 'u', 'o', 'n']), set(['e', 'o', 'g', 'l'])) # 重复的被删除 >>> x & y # 交集 set(['o']) >>> x | y # 并集 set(['b', 'e', 'g', 'l', 'o', 'n', 'r', 'u']) >>> x - y # 差集 set(['r', 'b', 'u', 'n']) >>>
1 篇笔记 写笔记
-
猎猎
178***8427@qq.com
239
>>> x = set('eleven') >>> y = set('twelve') >>> x,y ({'l', 'e', 'n', 'v'}, {'e', 'v', 'l', 't', 'w'}) >>> x & y #交集 {'l', 'e', 'v'} >>> x | y #并集 {'e', 'v', 'n', 'l', 't', 'w'} >>> x - y #差集 {'n'} >>> y -x #差集 {'t', 'w'} >>> x ^ y #补集 {'t', 'n', 'w'} >>> y ^ x #补集 {'w', 'n', 't'} >>>
交集 & : x&y,返回一个新的集合,包括同时在集合 x 和y中的共同元素。
并集 | : x|y,返回一个新的集合,包括集合 x 和 y 中所有元素。
差集 - : x-y,返回一个新的集合,包括在集合 x 中但不在集合 y 中的元素。补集 ^ : x^y,返回一个新的集合,包括集合 x 和 y 的非共同元素。
延伸阅读
对该解题方法的深入探讨