반응형

python 333

백준 BAEKJOON 13420번 사칙연산 [PYTHON/파이썬]

백준 BAEKJOON 13420번 사칙연산 [PYTHON/파이썬] (BRONZE Ⅱ) https://www.acmicpc.net/problem/13420 13420번: 사칙연산 사칙연산은 덧셈, 뺄셈, 곱셈, 나눗셈으로 이루어져 있으며, 컴퓨터 프로그램에서 이를 표현하는 기호는 +, -, *, / 와 같다. 아래는 컴퓨터 프로그램에서 표현한 사칙 연산의 예제이다. 3 * 2 = 6 문 www.acmicpc.net 주어지는 식을 문자열로 받아서 리스트로 저장했다. if문을 사용하여 +, -, *, / 마다의 조건을 건 뒤 결괏값과 비교하여 올바른 식이면 correct 그렇지 않으면 wrong answer를 출력했다. T = int(input()) for _ in range(T): expression = l..

ALGORITHM/PYTHON 2024.01.26

백준 BAEKJOON 13410번 거꾸로 구구단 [PYTHON/파이썬]

백준 BAEKJOON 13410번 거꾸로 구구단 [PYTHON/파이썬] (BRONZE Ⅱ) https://www.acmicpc.net/problem/13410 13410번: 거꾸로 구구단 일반적인 구구단에서 가장 큰 수는 마지막 항의 값이 제일 크다. 거꾸로 구구단에서는, 각 항에 구구단의 계산 결과로 나온 값을 뒤집어 저장을 한다. 이렇게 하면 가장 큰 값이 항상 마지막이 www.acmicpc.net for문을 통해 구구단을 구현하여 문자열로 거꾸로 만든 뒤 int형으로 변환 후 max를 통해 결과를 출력하였다. N, K = map(int, input().split()) googoodan = [int(str(N * i)[::-1]) for i in range(1, K + 1)] print(max(goo..

ALGORITHM/PYTHON 2024.01.25

백준 BAEKJOON 17496번 스타후르츠 [PYTHON/파이썬]

백준 BAEKJOON 17496번 스타후르츠 [PYTHON/파이썬] (BRONZE Ⅲ) https://www.acmicpc.net/problem/17496 17496번: 스타후르츠 1, 11, 21, 31, 41 일에 스타후르츠 씨앗을 심으면 됩니다. 51일에 심으면 61일에 수확이 가능한데 여름은 60일까지 이므로 61일에는 수확할 수 없습니다. 따라서 총 5 * 300 = 1500개의 스타후르츠를 수확 www.acmicpc.net 1일부터 N일까지 씨앗을 심었을 때 기간으로 나눠준 뒤 한 번에 심을 수 있는 씨앗과 가격을 각각 곱해주면 결과를 얻을 수 있다. N, T, C, P = map(int, input().split()) print((N - 1) // T * C * P)

ALGORITHM/PYTHON 2024.01.24

백준 BAEKJOON 11943번 파일 옮기기 [PYTHON/파이썬]

백준 BAEKJOON 11943번 파일 옮기기 [PYTHON/파이썬] (BRONZE Ⅳ) https://www.acmicpc.net/problem/11943 11943번: 파일 옮기기 첫 번째 줄에는 첫 번째 바구니에 있는 사과와 오렌지의 수 A, B가 주어진다. (0 ≤ A, B ≤ 1,000) 두 번째 줄에는 두 번째 바구니에 있는 사과와 오렌지의 수 C, D가 주어진다. (0 ≤ C, D ≤ 1,000) www.acmicpc.net ① 첫 번째 바구니의 사과 + 두 번째 바구니의 오렌지 ② 첫 번째 바구니의 오렌지 + 두 번째 바구니의 사과 ①, ②의 최솟값을 구하면 된다. A, B = map(int, input().split()) C, D = map(int, input().split()) prin..

ALGORITHM/PYTHON 2024.01.23

백준 BAEKJOON 10093번 숫자 [PYTHON/파이썬]

백준 BAEKJOON 10093번 숫자 [PYTHON/파이썬] (BRONZE Ⅱ) https://www.acmicpc.net/problem/10093 10093번: 숫자 두 양의 정수가 주어졌을 때, 두 수 사이에 있는 정수를 모두 출력하는 프로그램을 작성하시오. www.acmicpc.net 주어지는 A, B를 확인하여 작은 수를 A, 큰 수를 B에 저장한 후 for문을 돌려 A, B 사이의 정수를 확인하면 된다. A, B = map(int, input().split()) if A > B: A, B = B, A result = [i for i in range(A + 1, B)] print(len(result)) # 리스트 개수 출력 print(*result) # 리스트 한 줄 출력

ALGORITHM/PYTHON 2024.01.21

백준 BAEKJOON 10599번 페르시아의 왕들  [PYTHON/파이썬]

백준 BAEKJOON 10599번 페르시아의 왕들 [PYTHON/파이썬] (BRONZE Ⅲ) https://www.acmicpc.net/problem/10599 10599번: 페르시아의 왕들 테스트 케이스는 여러줄에 걸쳐 입력된다. 각 테스트 케이스는 4개의 정수 a, b, c, d (-5000 ≤ a ≤ b ≤ c ≤ d ≤ 2000)로 이뤄진다. [a, b]는 출생일의 범위, [c, d]는 사망일의 범위이다. a, b, c, d의 입력 www.acmicpc.net 사망일의 범위 최솟값 - 출생일의 범위 최댓값 = 최소 나이 사망일의 범위 최댓값 - 출생일의 범위 최솟값 = 최대 나이 while True: a, b, c, d = map(int, input().split()) if a == b == c ..

ALGORITHM/PYTHON 2024.01.14

백준 BAEKJOON 3035번 스캐너  [PYTHON/파이썬]

백준 BAEKJOON 3035번 스캐너 [PYTHON/파이썬] (BRONZE Ⅰ) https://www.acmicpc.net/problem/3035 3035번: 스캐너 첫째 줄에 R, C, ZR, ZC가 주어진다. R과 C는 1과 50 사이의 정수이고, ZR과 ZC는 1과 5 사이의 정수이다. 다음 R개 줄에는 신문 기사가 주어진다. www.acmicpc.net 2차원 배열을 이해하면 쉽게 풀 수 있다. 신문 기사의 글자를 리스트로 저장하여 ZC의 수만큼 사용하여 해당 글자들을 곱해준 뒤 ZR의 수만큼 늘려주면 된다. R, C, ZR, ZC = map(int, input().split()) paper = [input() for _ in range(R)] scanner = [] for i in range(..

ALGORITHM/PYTHON 2024.01.09

백준 BAEKJOON 13118번 뉴턴과 사과  [PYTHON/파이썬]

백준 BAEKJOON 13118번 뉴턴과 사과 [PYTHON/파이썬] (BRONZE Ⅳ) https://www.acmicpc.net/problem/13118 13118번: 뉴턴과 사과 첫 번째 줄에 사람들의 위치를 나타내는 네 정수 p1, p2, p3, p4 (−109 ≤ p1 < p2 < p3 < p4 ≤ 109)가 공백을 사이로 두고 주어진다. i번 (1 ≤ i ≤ 4) 사람은 (pi, 0) 위에 서 있다. 두 번째 줄에 사과의 정보 www.acmicpc.net 사과의 위치가 사람들이 서있는 위치와 동일한지 파악하면 된다. pos = list(map(int, input().split())) apple = list(map(int, input().split())) if apple[0] in pos: pr..

ALGORITHM/PYTHON 2024.01.08

백준 BAEKJOON 1764번 듣보잡  [PYTHON/파이썬]

백준 BAEKJOON 1764번 듣보잡 [PYTHON/파이썬] (SILVER Ⅳ) https://www.acmicpc.net/problem/1764 1764번: 듣보잡 첫째 줄에 듣도 못한 사람의 수 N, 보도 못한 사람의 수 M이 주어진다. 이어서 둘째 줄부터 N개의 줄에 걸쳐 듣도 못한 사람의 이름과, N+2째 줄부터 보도 못한 사람의 이름이 순서대로 주어진다. www.acmicpc.net 처음엔 리스트로 풀었더니 시간 초과가 떴다. 그래서 sys를 사용하였고 set 집합으로 생성 후 교집합(&)을 사용하여 문제를 풀 수 있었다. import sys input = sys.stdin.readline N, M = map(int, input().split()) A = set([input().rstrip()..

ALGORITHM/PYTHON 2024.01.07
반응형