码迷,mamicode.com
首页 > 其他好文 > 详细

苏州大学计算机复试机试 2018 年

时间:2020-06-06 18:25:27      阅读:60      评论:0      收藏:0      [点我收藏+]

标签:set   复试   new   his   计算   子集   题目   list   ret   

题目

在20000个数中找一个满足下列条件的最大集合:
集合中所有数之间的最大公因数是1(即两两互质)

代码

def _2018(arr: list):

    # 准备工具
    arr = list(set(arr))
    arr.sort()
    size = len(arr)
    my_dict = {}

    # 因式分解
    def f1(n):
        if n < 4:
            return [n]
        i = 2
        factors = []
        while n > 1:
            f = 0
            while n % i == 0:
                f = 1
                n = n // i
            if f:
                factors.append(i)
            i += 1
        return factors

    def f2(old_set, new_set):
        i, j = 0, 0
        s1, s2 = len(old_set), len(new_set)
        while i < s1 and j < s2:
            if old_set[i] < new_set[j]:
                i += 1
            elif old_set[i] > new_set[j]:
                j += 1
            else:
                return False
        return True

    #求个数==各数因子
    for k in arr:
        my_dict[k] = f1(k)
    arr[0] = arr[0] if arr[0] != 1 else 2

    # 求最大子集
    M = 0
    ans = set()
    for i in range(size):
        p = set()
        vs = my_dict[arr[i]]
        p.add(arr[i])
        for j in range(size):
            this_factors =  my_dict[arr[j]]
            if f2(vs, this_factors):
                p.add(arr[j])
                vs = vs | this_factors
        if len(p) > M:
            M = len(p)
            ans = p

    return ans

请勿用于商业用途
欢迎加入苏大计算机考研群QQ 398158655
有任何疑问 QQ 1793882124

苏州大学计算机复试机试 2018 年

标签:set   复试   new   his   计算   子集   题目   list   ret   

原文地址:https://www.cnblogs.com/tstk/p/13055644.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!