Python3求m以内的素数、求m个数中最小的n个数

[本文出自天外归云的博客园]

题1:求m以内的素数(m>2)

def find_all_primes_in(m):
    def prime(num):
        for i in range(2, num):
            if divmod(num, i)[1] == 0:
                return False
        return True

    print([i for i in range(2, m + 1) if prime(i)])


if __name__ == '__main__':
    find_all_primes_in(100)

我还有一种效率不是最高,但是写法最短的一行版求2到100以内的素数的写法:

print(list(filter(lambda num: False not in set([False if divmod(num, i)[1] == 0 else True for i in range(2, num)]), [i for i in range(2, 101)])))

这种方法的优点是只有一行,缺点是判断素数的方法不好,把之前所有的数都遍历了一遍并判断是否能够整除,最后才得出是否是素数的结论。正确的方法是遍历之前的数,如果出现了能整除的直接就返回False不再继续判断。 

题2:求m个数中最小的n个数(m>n)

def get_max(data):
    max, index = data[0], 0
    for i in range(1, len(data)):
        if data[i] > max:
            max, index = data[i], i

    return max, index


def get_min(data, n, min=[]):
    for dt in data:
        if len(min) < n:
            min.append(dt)
        else:
            max, index = get_max(min)
            if dt < max:
                min[index] = dt

    print(sorted(min))


if __name__ == '__main__':
    data = [2, 55, 41, 2, 56, 89, 85, 45, 15, 3, 6, 4, 89, 75, 21, 10, 20, 31, 226, 10, 225, 456, 895, 42, 14, 547, 61,
            45, 95, 84, 81]
    get_min(data, 5)
原文地址:https://www.cnblogs.com/LanTianYou/p/9140297.html