CodingTest/Baekjoon

[백준/Python] 4134번 : 다음 소수

2023. 5. 28. 09:00
728x90
 

4134번: 다음 소수

첫째 줄에 테스트 케이스의 개수가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있고, 정수 n이 주어진다.

www.acmicpc.net


시간 제한  메모리 제한 문제 티어 정답 비율
1 초 128 MB
실버 IV
25.145%

📜 문제

정수 n(0 ≤ n ≤ 4*10^9)가 주어졌을 때, n보다 크거나 같은 소수 중 가장 작은 소수 찾는 프로그램을 작성하시오.

 

📥입력

첫째 줄에 테스트 케이스의 개수가 주어진다. 각 테스트 케이스는 한 줄로 이루어져 있고, 정수 n이 주어진다.

 

 

📤출력

각각의 테스트 케이스에 대해서 n보다 크거나 같은 소수 중 가장 작은 소수를 한 줄에 하나씩 출력한다.

 

💡풀이

기본적으로 해당 num이 소수인지 확인하는 알고리즘 풀이법은 총 3가지가 있다.
 
1. 아예 num을 2부터 num까지 나누어서 확인하는 알고리즘 => 시간복잡도 O(n)
2. num을 2부터 num/2까지 나누어서 확인하는 알고리즘 => 시간복잡도 O(n)
3. num을 2부터 √num 까지 나누어서 구하는 알고리즘(num의 약수의 중간을 구하는 원리) => 시간복잡도 O(√n)
 
나는 3번째 방법을 사용해서 is_prime() 함수를 만들어줬고, num이 소수가 아닐 경우 next_num() 함수에서 다음 num으로 넘어가 다시 소수를 확인하는 식으로 아래와 같이 코드를 작성했다. 
import sys
import math

def is_prime(num):
  if num == 0 or num == 1:
    return False
  else:
    for i in range(2, int(math.sqrt(num)) + 1):
      if num % i == 0:
        return False
    return num

def next_num(num):
  while True:
    if is_prime(num) == False:
      num += 1
    elif is_prime(num):
      return num

input = sys.stdin.readline

times = int(input())

for _ in range(times):
  num = int(input())
  print(next_num(num))

 

'CodingTest > Baekjoon' 카테고리의 다른 글

[백준/Python] 10815번 : 숫자 카드  (0) 2023.05.30
[백준/Python] 2563번 : 색종이  (0) 2023.05.29
[백준/Python] 1735번 : 분수 합  (0) 2023.05.27
[백준/Python] 13241번 : 최소공배수  (0) 2023.05.26
[백준/Python] 2501번 : 약수 구하기  (0) 2023.05.24
'CodingTest/Baekjoon' 카테고리의 다른 글
  • [백준/Python] 10815번 : 숫자 카드
  • [백준/Python] 2563번 : 색종이
  • [백준/Python] 1735번 : 분수 합
  • [백준/Python] 13241번 : 최소공배수
JuniTech
JuniTech
프로그래밍을 정복하기 위한 좌충우돌 코린이의 기록
JuniTech
Juni IT Technology
JuniTech
전체
오늘
어제
  • 분류 전체보기 (83)
    • Develop (29)
      • C, C++ (13)
      • Python (9)
      • Java (1)
      • JavaScript (0)
      • Arduino Uno (6)
    • CodingTest (38)
      • Baekjoon (36)
    • Project (0)
    • IT Issue (1)
    • Computer Science (11)
      • 프로그래밍 언어론 (3)
      • Open Source (3)
      • Data Structure (5)

블로그 메뉴

  • 홈
  • 태그
  • 방명록
  • 🧑‍💻Github
  • 😎Juni의 잡동사니(일상 블로그)
  • 💰Juni의 투자일기(주식 블로그)

공지사항

인기 글

태그

  • LCD
  • 파스트리
  • 10810
  • 27866
  • Backjoon
  • 포인터
  • 프로그래밍 어론
  • 프로그래밍어론
  • 생존시간
  • c++
  • 25206
  • 아두이노 우노
  • 프로그래밍 역사
  • pygame
  • 2083번
  • 백준
  • 10811
  • 10988
  • C
  • 11000
  • 13241
  • 10798
  • 10812
  • Python
  • 프어론
  • 10813
  • 구문법
  • 파이썬
  • 10797
  • 문자열

최근 댓글

최근 글

hELLO · Designed By 정상우.
JuniTech
[백준/Python] 4134번 : 다음 소수
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.