파이썬 알고리즘 009 | 주사위 게임

Yunny.Log ·2021년 1월 6일
0

Algorithm

목록 보기
9/318
post-thumbnail

9.주사위 게임

1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게
임이 있다.
규칙(1) 같은 눈이 3개가 나오면 10,000원+(같은 눈)1,000원의 상금을 받게 된다.
규칙(2) 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)100원의 상금을 받게 된다.
규칙(3) 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)100원의 상금을 받게 된다.
예를 들어, 3개의 눈 3, 3, 6이 주어지면 상금은 1,000+3100으로 계산되어 1,300원을 받게 된다. 또 3개의 눈이 2, 2, 2로 주어지면 10,000+21,000 으로 계산되어 12,000원을 받게 된다.3개의 눈이 6, 2, 5로 주어지면 그 중 가장 큰 값이 6이므로 6100으로 계산되어 600원을 상금으로 받게 된다.
N 명이 주사위 게임에 참여하였을 때, 가장 많은 상금을 받은 사람의 상금을 출력하는 프로그램
을 작성하시오.

▣ 입력설명
첫째 줄에는 참여하는 사람 수 N(2<=N<=1,000)이 주어지고 그 다음 줄부터 N개의 줄에 사람
들이 주사위를 던진 3개의 눈이 빈칸을 사이에 두고 각각 주어진다.

▣ 출력설명
첫째 줄에 가장 많은 상금을 받은 사람의 상금을 출력한다.

▣ 입력예제 1
3 3
3 3 6
2 2 2
6 2 5

▣ 출력예제 1
12000

<내 코드>

n=int(input())
aa=[]

for i in range(n) :
    a=list(map(int, input().split()))
    for i in a :
        if a.count(i)==3:
            b=(10000+i*1000)
            aa.append(b)
        elif a.count(i)==2:
            c=(1000+i*100)                
            aa.append(c)
        else : 
            d=(max(a)*100)
            aa.append(d)
print(max(aa))

=> 답은 나오지만 사실 print(aa) 하면 무슨 거의 모든 경우의 수 나오듯이 우수수 쏟아져서 나온다 그래서 더 생각해보자

n=int(input())
com=[]
for i in range(n) :
    a=list(map(int, input().split()))
    for i in a :
        if a.count(i)==3:
           prize=(10000+i*1000)
           com.append(prize)
           break
        elif a.count(i)==2:
            prize=(1000+i*100)  
            com.append(prize)
            break
        else : 
            prize=(max(a)*100)
            com.append(prize)
            break
print(max(com))

=> 처음 코드에서 저 조건 중 하나라도 만족하면 그때 가격이 정해지므로 멈췄어야 하는데 그냥 계속 돌렸더니 처음 케이스(3,3,6 입력) 하면 두번째 elif조건에 3,3이 걸리고 (1300두번 출력) 마지막에 6은 else조건에 걸려서 자꾸 print(com)하면 9개씩 나오고 이랬던 것이다...
잘 생각하면서 코드를 작성하도록 하자

<풀이>

=>그냥 if elif, else 이렇게 이용하면 되는 것이다
그리고 이런 여러가지 조건문을 쓸 때는 항상 최상의 조건부터 쓰자!


n=int(input())
res=0
for i in range(n) :
    tmp=input().split()
    tmp.sort()
    a, b, c=map(int, tmp)
    if a==b and b==c :
    	money = 10000+a*1000
    elif a==b or b==c :
    	money = 1000+b*100
    elif b==c :
    	money = 1000+b*100
    else : 
    	money = c*100 	#위에서 정렬을 미디 해두었기에 c가 최대값
    if money > res :  
        res=money
print(res)

<반성점>

  • 처음 코드에서 저 조건 중 하나라도 만족하면 그때 가격이 정해지므로 멈췄어야 하는데 그냥 계속 돌렸더니 처음 케이스(3,3,6 입력) 하면 두번째 elif조건에 3,3이 걸리고 (1300두번 출력) 마지막에 6은 else조건에 걸려서 자꾸 print(com)하면 9개씩 나오고 이랬던 것이다...
    잘 생각하면서 코드를 작성하도록 하자

<배운 점>

  • if elif, else 이런 여러가지 조건문을 쓸 때는 항상 최상의 조건부터 쓰자!
  • 비교 개수가 적으면 각각의 변수에 unpack해서 조건문으로 비교해 주는 것으로도 충분하다.
  • 리스트를 여러개 입력해야 한다면 일단 반복문 안에서 한 리스트씩 해결해서 값을 비교해보자.

0개의 댓글