Python|每日一练|蚂蚁家族|通信连接模型|set函数|:蚂蚁家族

目录

题目名称:蚂蚁家族

时间限制:1000ms内存限制:256M

题目描述

输入描述

输出描述

示例 

提示

实现代码

PS:SET()

描述

语法

返回值

实例

延伸阅读


题目名称:蚂蚁家族

时间限制: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']) >>>

正在上传…重新上传取消 Python 内置函数

 Python OS 文件/目录方法

Python 面向对象

1 篇笔记 写笔记

  1.    猎猎

      178***[email protected]

    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 的非共同元素。

延伸阅读

对该解题方法的深入探讨

Python解题 - CSDN周赛第12期 - 蚂蚁的烦恼_请叫我问哥的博客-CSDN博客_编程题豚鼠排名榜

你可能感兴趣的:(每日一练,leetcode,python,算法)