Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- Real or Not? NLP with Disaster Tweets
- 코로나19
- 자연어처리
- Baekjoon
- 더현대서울 맛집
- 편스토랑 우승상품
- 우분투
- programmers
- Docker
- 백준
- 맥북
- Git
- 프로그래머스
- dacon
- leetcode
- 캐치카페
- 프로그래머스 파이썬
- 금융문자분석경진대회
- 데이콘
- Kaggle
- PYTHON
- ubuntu
- github
- ChatGPT
- AI 경진대회
- gs25
- 편스토랑
- SW Expert Academy
- 파이썬
- hackerrank
Archives
- Today
- Total
솜씨좋은장씨
[BaekJoon] 1296번 : 데이트 (Python) 본문
728x90
반응형
코딩 1일 1문제! 오늘의 문제는 백준의 데이트 입니다.
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_name.count("V")
E = girl_name.count("E") + minsik_name.count("E")
score = ((L+O)*(L+V)*(L+E)*(O+V)*(O+E)*(V+E)) % 100
scores.append((score, girl_name))
scores.sort(key=lambda x: (-x[0], x[1]))
return scores[0][1]
if __name__ == "__main__":
girl_names = []
minsik_name = input()
for _ in range(int(input())):
girl_name = input()
girl_names.append(girl_name)
print(get_best_try(minsik_name, girl_names))
Solution 풀이
먼저 민식이의 이름을 입력 받고 데이트할 여성의 이름을 입력 받습니다.
그 다음 민식이 이름과 각 여성의 이름에서 "L", "O", "V", "E"의 개수를 구하여
더한 값들을 L, O, V, E 변수에 넣어주고
score = ((L+O)*(L+V)*(L+E)*(O+V)*(O+E)*(V+E)) % 100
위의 값을 구하여 이름과 함께 리스트에 저장해 두었다가
점수를 기준으로 내림차순 이름을 기준으로 오름차순 정렬하고
그 중 가장 앞에 있는 이름을 return하여 출력하면 끝!
'Programming > 코딩 1일 1문제' 카테고리의 다른 글
[BaekJoon] 13163번 : 닉네임에 갓 붙이기 (Python) (0) | 2021.06.23 |
---|---|
[BaekJoon] 1990번 : 소수인팰린드롬 (Python) (0) | 2021.06.22 |
[BaekJoon] 2711번 : 오타맨 고창영 (Python) (0) | 2021.06.20 |
[BaekJoon] 9086번 : 문자열 (Python) (0) | 2021.06.19 |
[BaekJoon] 1076번 : 저항 (Python) (0) | 2021.06.18 |
Comments