Why not login to Qiita and try out its useful features?

We'll deliver articles that match you.

You can read useful information later.

0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

[python] 自然数N以下の素数をすべて求める

Posted at

はじめに

素数に関するアルゴリズム問題は定番なので、少し勉強した

問題

自然数N以下のすべての素数を求めよ

Code

from typing import List


def generate_primes(number: int) -> List[int]:

    # 素数
    primes = []

    # for文の作業を減らすために、cahceで繰り返しを減らす
    cache = {}

    for x in range(2, number + 1):
        is_prime = cache.get(x)
        if is_prime is False:
            continue

        # 素数である
        primes.append(x)
        cache[x] = True

        # x の倍数はすべて素数ではないので、cacheのFalseとして処理
        for y in range(x*2, number+1, x):
            cache[y] = False

    return primes


結果

print(generate_primes(100))
# [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97]

感想

二重for文でアルゴリズム問題を解けなかったことが多かったが、dicでcacheを利用することによって時間・作業の短縮ができることを初めて知った

0
0
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up

Qiita Conference 2025 will be held!: 4/23(wed) - 4/25(Fri)

Qiita Conference is the largest tech conference in Qiita!

Keynote Speaker

ymrl、Masanobu Naruse, Takeshi Kano, Junichi Ito, uhyo, Hiroshi Tokumaru, MinoDriven, Minorun, Hiroyuki Sakuraba, tenntenn, drken, konifar

View event details
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?