일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- programmers
- 프로그래머스
- ubuntu
- dacon
- AI 경진대회
- 백준
- Real or Not? NLP with Disaster Tweets
- github
- 코로나19
- 맥북
- 편스토랑 우승상품
- hackerrank
- 파이썬
- PYTHON
- 우분투
- leetcode
- 데이콘
- 프로그래머스 파이썬
- 자연어처리
- Git
- Kaggle
- Baekjoon
- 금융문자분석경진대회
- 캐치카페
- SW Expert Academy
- ChatGPT
- 더현대서울 맛집
- 편스토랑
- gs25
- Docker
- Today
- Total
목록
반응형
백준 (399)
솜씨좋은장씨
코딩 1일 1문제! 오늘의 문제는 백준의 더하기 입니다. 10822번: 더하기 첫째 줄에 문자열 S가 주어진다. S의 길이는 최대 100이다. 포함되어있는 정수는 1,000,000보다 작거나 같은 자연수이다. www.acmicpc.net Solution def custom_sum(string): return sum(list(map(int, string.split(",")))) if __name__ == "__main__": input_string = input() print(custom_sum(input_string)) SOMJANG/CODINGTEST_PRACTICE 1일 1문제 since 2020.02.07. Contribute to SOMJANG/CODINGTEST_PRACTICE developme..
코딩 1일 1문제! 오늘의 문제는 백준의 베스트셀러 입니다. 1302번: 베스트셀러 첫째 줄에 오늘 하루 동안 팔린 책의 개수 N이 주어진다. 이 값은 1,000보다 작거나 같은 자연수이다. 둘째부터 N개의 줄에 책의 제목이 입력으로 들어온다. 책의 제목의 길이는 50보다 작거나 같고 www.acmicpc.net Solution def best_seller(book_list): best_check = {} for book in book_list: if book not in best_check.keys(): best_check[book] = 1 else: best_check[book] += 1 best_sell_num = max(best_check.values()) best_list = [sell_book..
코딩 1일 1문제! 오늘의 문제는 백준의 끝말잇기 입니다. 20528번: 끝말잇기 욱제는 준원이랑 끝말잇기를 하고 있다. 준원이가 시작하자마자 '스트론튬'을 외쳐서 욱제는 피가 거꾸로 솟았다~ 솟으면 백두산~ 백두산은 높아~ 높으면 비행기~ 비행기는 빨라~ 빠르면 기차~ www.acmicpc.net Solution def end_to_end(num, string): is_end_to_end = 1 if num > 0: split_str = string.split() compare_word = split_str[-1] for i in range(1, num): if split_str[i] != compare_word: is_end_to_end = 0 break compare_word = split_str[..
코딩 1일 1문제! 오늘의 문제는 백준의 유학 금지입니다. 2789번: 유학 금지 아주 멀리 떨어져 있는 작은 나라가 있다. 이 나라에서 가장 공부를 잘하는 학생들은 모두 다른 나라로 유학을 간다. 정부는 최고의 학생들이 자꾸 유학을 가는 이유를 찾으려고 했다. 하지만, www.acmicpc.net Solution def study_abroad_prohibition(string): cambridge = set("CAMBRIDGE") return "".join([char for char in string if char not in cambridge]) if __name__ == "__main__": string = input() print(study_abroad_prohibition(string)) SOM..
코딩 1일 1문제! 오늘의 문제는 백준의 균형잡힌 세상입니다. 4949번: 균형잡힌 세상 하나 또는 여러줄에 걸쳐서 문자열이 주어진다. 각 문자열은 영문 알파벳, 공백, 소괄호("( )") 대괄호("[ ]")등으로 이루어져 있으며, 길이는 100글자보다 작거나 같다. 입력의 종료조건으로 맨 마 www.acmicpc.net Solution import re def balanced_world(string): is_balanced = "yes" my_stack = [] open_bracket = ['(', '['] close_bracket = [')', ']'] braket_list = list(re.sub(r"[^\(\)\[\]]", '', string)) for idx, bracket in enumerat..
코딩 1일 1문제! 오늘의 문제는 백준의 좋은 자동차 번호판 입니다. 1871번: 좋은 자동차 번호판 각각의 자동차 번호판에 대해서, 좋은 번호판이면 "nice"를, 아니면 "not nice"를 출력한다. www.acmicpc.net Solution def nice_car_number(car_number): is_nice = "not nice" front, end = car_number.split("-") front_num, end_num = 0, int(end) for i in range(3): front_num += (ord(front[i]) - 65) * 26**(2-i) if abs(front_num - end_num)
코딩 1일 1문제! 오늘의 문제는 백준의 무한 문자열 입니다. 12871번: 무한 문자열 첫째 줄에 s, 둘째 줄에 t가 주어진다. 두 문자열 s와 t의 길이는 50보다 작거나 같은 자연수이고, 알파벳 소문자로만 이루어져 있다. www.acmicpc.net Solution import math def get_least_common_multiple(string_s_len, string_t_len): return string_s_len * string_t_len // math.gcd(string_s_len, string_t_len) def infinity_string(string_s, string_t): is_infinity_string = 0 string_s_len = len(string_s) string..
코딩 1일 1문제! 오늘의 문제는 백준의 파일 정리 입니다. 20291번: 파일 정리 친구로부터 노트북을 중고로 산 스브러스는 노트북을 켜자마자 경악할 수밖에 없었다. 바탕화면에 온갖 파일들이 정리도 안 된 채 가득했기 때문이다. 그리고 화면의 구석에서 친구의 메시지를 www.acmicpc.net Solution from collections import Counter def arrange_files(file_list): file_formats = [] for file in file_list: _, file_format = file.split(".") file_formats.append(file_format) cnt = Counter(file_formats).items() sorted_list = sor..
코딩 1일 1문제! 오늘의 문제는 백준의 문자가 몇갤까 입니다. 7600번: 문자가 몇갤까 각 줄마다 출몰한 알파벳의 개수를 출력하면 된다. www.acmicpc.net Solution import re def get_word_nums(string): string = re.sub(r"[^a-z]", '', string.lower()) alphabets = list(set(string)) return len(alphabets) if __name__ == "__main__": while True: string = input() if string == "#": break print(get_word_nums(string)) Solution 풀이 문자열은 #이 입력될때 까지 계속 입력 받습니다. 입력받은 문자열을..
코딩 1일 1문제! 오늘의 문제는 백준의 알파벳 전부 쓰기입니다. 11091번: 알파벳 전부 쓰기 팬그램은 26개의 알파벳, a~z를 최소 한번씩 모두 사용한 문장을 말한다. 아마 가장 유명한 문장은 이것일 것이다. "The quick brown fox jumps over the lazy dog." 꿍은 다른 문장들중에 팬그램인 것은 없는지 www.acmicpc.net Solution import re def use_all_alphabet(string, alphabets): is_pangram = "pangram" string = re.sub(r"[^a-z]", '', string.lower()) string = set(string) not_uesd_alphabet = alphabets - string ..
코딩 1일 1문제! 오늘의 문제는 백준의 행복한지 슬픈지 입니다. 행복한지 슬픈지 보지않아도 모두가 행복한 하루였으면 좋겠습니다~ 10769번: 행복한지 슬픈지 승엽이는 자신의 감정을 표현하기 위해서 종종 문자 메시지에 이모티콘을 넣어 보내곤 한다. 승엽이가 보내는 이모티콘은 세 개의 문자가 붙어있는 구조로 이루어져 있으며, 행복한 얼굴을 나 www.acmicpc.net Solution def happy_or_sad(mind_string): mind = None happy, sad = 0, 0 split_string = mind_string.split(":") for split_str in split_string: if split_str[:2] == "-)": happy += 1 elif split_st..
코딩 1일 1문제! 오늘의 문제는 백준의 수학숙제 입니다. 2870번: 수학숙제 종이에서 찾은 숫자의 개수를 M이라고 하면, 출력은 M줄로 이루어져야 한다. 각 줄에는 종이에서 찾은 숫자를 하나씩 출력해야 한다. 이때, 비내림차순으로 출력해야 한다. 비내림차순은 내림차 www.acmicpc.net Solution import re def math_homework(papers): number_list = [] for paper in papers: numbers = re.findall("\d+", paper) numbers = list(map(int, numbers)) number_list += numbers number_list.sort() for number in number_list: print(num..
코딩 1일 1문제! 오늘의 문제는 사칙연산 입니다. 13420번: 사칙연산 사칙연산은 덧셈, 뺄셈, 곱셈, 나눗셈으로 이루어져 있으며, 컴퓨터 프로그램에서 이를 표현하는 기호는 +, -, *, / 와 같다. 아래는 컴퓨터 프로그램에서 표현한 사칙 연산의 예제이다. 3 * 2 = 6 문 www.acmicpc.net Solution def arithmetic_operation(mathematical_expression): is_correct = "wrong answer" num1, operator, num2, _, result = mathematical_expression.split() num1, num2, result = int(num1), int(num2), int(result) if (operator ..
코딩 1일 1문제! 오늘의 문제는 백준의 히든 넘버입니다. 8595번: 히든 넘버 첫째 줄에 단어의 길이 n (1 ≤ n ≤ 5,000,000)이 주어진다. 둘째 줄에는 단어가 주어진다. 단어는 알파벳 대/소문자와 숫자(0-9)로 이루어져 있다. www.acmicpc.net Solution import re def hidden_number(string): numbers = re.findall("\d+", string) numbers = list(map(int, numbers)) return sum(numbers) if __name__ == "__main__": str_len = input() string = input() print(hidden_number(string)) Solution 풀이 이번엔 정..
코딩 1일 1문제! 오늘의 문제는 백준의 럭키 스트레이트입니다. 18406번: 럭키 스트레이트 첫째 줄에 점수 N이 정수로 주어진다. (10 ≤ N ≤ 99,999,999) 단, 점수 N의 자릿수는 항상 짝수 형태로만 주어진다. www.acmicpc.net Solution def lucky_straight(score): state = "READY" median_idx = len(score) // 2 score1, score2 = score[:median_idx], score[median_idx:] score1 = sum(list(map(int, str(score1)))) score2 = sum(list(map(int, str(score2)))) if score1 == score2: state = "LUC..
코딩 1일 1문제! 오늘의 문제는 백준의 신용카드 판별 입니다. 14726번: 신용카드 판별 신용카드는 총 16자리의 숫자로 구성되어 있다. 언뜻 보기에는 무작위로 된 숫자로 구성되어 있는 것 같이 보이지만 그 속에는 하나의 수학적 비밀이 숨겨져 있다. 그중 하나가 카드 번호가 유효 www.acmicpc.net Solution def check_credit_card_number(card_number): is_valid = "F" sum_num = 0 card_number = list(card_number) for i, card_num in enumerate(card_number): if (i + 1) % 2 != 0: number = int(card_num) * 2 if number > 9: number..
코딩 1일 1문제! 오늘의 문제는 백준의 이상한 곱셈입니다. 1225번: 이상한 곱셈 첫째 줄에 A와 B가 주어진다. 주어지는 두 수는 모두 10,000자리를 넘지 않는다. www.acmicpc.net 첫번째 시도 def strange_multiplication(string): result = 0 number1, number2 = string.split() for num1 in number1: for num2 in number2: result += int(num1) * int(num2) return result if __name__ == "__main__": string = input() print(strange_multiplication(string)) 먼저 숫자 두개를 입력 받은 뒤에 공백으로 spl..
코딩 1일 1문제! 오늘의 문제는 백준의 소수 단어 입니다. 2153번: 소수 단어 소수란 1과 자기 자신으로만 나누어떨어지는 수를 말한다. 예를 들면 1, 2, 3, 5, 17, 101, 10007 등이 소수이다. 이 문제에서는 편의상 1도 소수로 하자. 알파벳 대소문자로 이루어진 영어 단어가 하나 www.acmicpc.net Solution def check_is_primary_num(num): for i in range(2, int(num**0.5) + 1): if num % i == 0: return "It is not a prime word." return "It is a prime word." def change_word_to_num(word): num = 0 for char in word: ..
코딩 1일 1문제! 오늘의 문제는 백준의 세로읽기입니다. 10798번: 세로읽기 총 다섯줄의 입력이 주어진다. 각 줄에는 최소 1개, 최대 15개의 글자들이 빈칸 없이 연속으로 주어진다. 주어지는 글자는 영어 대문자 ‘A’부터 ‘Z’, 영어 소문자 ‘a’부터 ‘z’, 숫자 ‘0’ www.acmicpc.net Solution def read_vertical(strings): read_string = [] max_len = max([len(string) for string in strings]) for i in range(max_len): for string in strings: if len(string) - 1 >= i: read_string.append(string[i]) return "".join(re..
오늘의 문제는 백준의 회사에 있는 사람 입니다. 7785번: 회사에 있는 사람 첫째 줄에 로그에 기록된 출입 기록의 수 n이 주어진다. (2 ≤ n ≤ 106) 다음 n개의 줄에는 출입 기록이 순서대로 주어지며, 각 사람의 이름이 주어지고 "enter"나 "leave"가 주어진다. "enter"인 경우는 www.acmicpc.net Solution 1 def company_people(access_record): record_dict = {} for access in access_record: name, status = access.split() if status == "enter": record_dict[name] = status else: del record_dict[name] return sorte..
코딩 1일 1문제! 오늘의 문제는 퇴근하기 전 제 마음과 같았던 아! 입니다. 제목에 끌려 풀었는데 아주 쉬웠던 문제였습니다. 4999번: 아! 입력은 두 줄로 이루어져 있다. 첫째 줄은 재환이가 가장 길게 낼 수 있는 "aaah"이다. 둘째 줄은 의사가 듣기를 원하는 "aah"이다. 두 문자열은 모두 a와 h로만 이루어져 있다. a의 개수는 0보다 크거 www.acmicpc.net Solution def is_go_hospital(doctor, justin_bieber): is_go = "no" if len(doctor)
코딩 1일 1문제! 오늘의 문제는 백준의 연속구간 입니다. 2495번: 연속구간 여덟 자리의 양의 정수가 주어질 때, 그 안에서 연속하여 같은 숫자가 나오는 것이 없으면 1을 출력하고, 있으면 같은 숫자가 연속해서 나오는 구간 중 가장 긴 것의 길이를 출력하는 프로그램을 www.acmicpc.net Solution def get_longest_repeat_time(string): answer, cnt = 1, 1 for i in range(1, len(string)): if string[i] == string[i-1]: cnt += 1 if cnt > answer: answer = cnt else: cnt = 1 return answer if __name__ == "__main__": for _ in r..
코딩 1일 1문제 오늘의 문제는 백준의 대소문자 바꾸기 입니다. 2744번: 대소문자 바꾸기 영어 소문자와 대문자로 이루어진 단어를 입력받은 뒤, 대문자는 소문자로, 소문자는 대문자로 바꾸어 출력하는 프로그램을 작성하시오. www.acmicpc.net Solution def change_lower_upper(string): new_string = [] for char in string: if char.isupper(): new_string.append(char.lower()) elif char.islower(): new_string.append(char.upper()) return "".join(new_string) if __name__ == "__main__": string = input() print..
코딩 1일 1문제! 오늘의 문제는 알파벳 거리입니다. 5218번: 알파벳 거리 첫째 줄에 테스트 케이스의 수 (= str_1: distance = str(str_2 - str_1) else: distance = str(str_2 +..
코딩 1일 1문제! 오늘의 문제는 백준의 모음의 개수입니다. 10987번: 모음의 개수 알파벳 소문자로만 이루어진 단어가 주어진다. 이때, 모음(a, e, i, o, u)의 개수를 출력하는 프로그램을 작성하시오. www.acmicpc.net Solution from collections import Counter def count_vowel(string): vowels = ['a', 'e', 'i', 'o', 'u'] cnt = Counter(string).items() vowel_cnt = [count[1] for count in cnt if count[0] in vowels] return sum(vowel_cnt) if __name__ == "__main__": string = input() prin..
코딩 1일 1문제! 오늘의 문제는 백준의 IBM 빼기 1 입니다. 6321번: IBM 빼기 1 첫째 줄에 컴퓨터의 개수 n이 주어진다. 다음 줄부터 n개의 줄에는 컴퓨터의 이름이 주어진다. 컴퓨터의 이름은 최대 50글자이며, 알파벳 대문자로만 이루어져 있다. www.acmicpc.net Solution def ibm_subtract(string): computer_name = "" for char in string: if char == "Z": computer_name += "A" else: computer_name += chr(ord(char) + 1) return computer_name if __name__ == "__main__": for i in range(int(input())): string..
코딩 1일 1문제! 오늘의 문제는 백준의 닉네임에 갓 붙이기 입니다. 13163번: 닉네임에 갓 붙이기 첫 번째 줄에는 닉네임의 수 N(1 ≤ N ≤ 100)이 주어진다. 두 번째 줄부터 N개의 줄에는 음절 단위로 쪼갠 닉네임이 주어진다. 각 줄은 알파벳 소문자와 공백만으로 이루어지며, 쪼갠 닉네임의 총 www.acmicpc.net Solution def make_god_name(name): name = name.split() name[0] = "god" return "".join(name) if __name__ == "__main__": for _ in range(int(input())): name = input() print(make_god_name(name)) Solution 풀이 먼저 입력 받은 ..
코딩 1일 1문제! 오늘의 문제는 백준의 소수인팰린드롬 입니다. 1990번: 소수인팰린드롬 151은 소수이면서 동시에 팰린드롬이기 때문에 소수인 팰린드롬이다. 팰린드롬이란 앞으로 읽어나 뒤로 읽으나 같은 수를 말한다. 예를 들어 1234는 앞으로 읽으면 1234지만, 뒤로 읽으면 4321이 되 www.acmicpc.net 첫번째 시도! def get_primary_num_eratos(N): nums = [True] * (N) for i in range(2, len(nums) // 2 + 1): if nums[i] == True: for j in range(i+i, N, i): nums[j] = False return [i for i in range(2, N) if nums[i] == True] def c..
코딩 1일 1문제! 오늘의 문제는 백준의 데이트 입니다. 1296번: 데이트 첫째 줄에 오민식의 영어 이름이 주어진다. 둘째 줄에는 좋아하는 여자가 몇 명인지 N이 주어지고, 셋째 줄부터 N개의 줄에 여자의 이름이 하나 씩 주어진다. N은 50보다 작거나 같고, 모든 이름은 www.acmicpc.net Solution def get_best_try(minsik_name, girl_names): scores = [] for girl_name in girl_names: L = girl_name.count("L") + minsik_name.count("L") O = girl_name.count("O") + minsik_name.count("O") V = girl_name.count("V") + minsik_n..
코딩 1일 1문제! 오늘의 문제는 백준의 오타맨 고창영 입니다. 2711번: 오타맨 고창영 첫째 줄에 테스트 케이스의 개수 T(1