알고리즘/알고리즘 기초공부

동빈나 2021 이코테_2-1.구현 (시뮬레이션, 완전탐색)

이숭간 2021. 2. 1. 23:16
728x90
  • 구현 : 머릿속에 있는 알고리즘을 소스코드로 바꾸는 과정 / 문제에서 요구하것이 구현에 맞춰져 있는문제들
  • 즉 풀이를 떠올리는것은 쉽지만 소스코드로 옮기기 어려운 문제를 말함

 

  • 예를들면 알고리즘은 간단한데 코드가 지나치게 길어지는문제
  • 실수연산, 특정소수점자리까지 출력해야하는 문제
  • 문자열을 특정한 기준에 따라 끊어 처리해야 하는 문제 ( 문자열처리는 파이썬이 강력함 )
  • 적절한 라이브러리를 찾아 사용해야 하는 문제

 

 예제문제 1 ) 상하좌우 이동시키기

내가 작성한 코드

n = int(input())
plan = list(input().split())


row = 1
line = 1

for move in plan:
    if move == 'R':
        if line == n:
            continue
        line +=1
    elif move == 'U':
        if row == 1:
            continue
        row -= 1
    elif move == 'L':
        if line == 1:
            continue
        line -= 1
    elif move == 'D':
        if row == n:
            continue
        row += 1
        
    
print(row, line)

동빈나님 정답코드

차이점 : 나는 if문을 4개써서 L,R,U,D를 체크한것과 달리 동빈나님은 배열을 써서 포문을 돌리면서 if문으로 체크함

공간에서 벗어나는 조건 확인하는 부분에서, nx와 같은 임시(?) 위치를 두고 그 위치가 벗어나면 원본위치를 바꾸지않고 넘어가는식으로함

나는 그냥 그떄그때 원본위치를 확인함 

 

스위치문이 필요할것같은상황 = 포문+이프문

 

예제문제2 ) 시각_3이 하나라도있는 경우의수

내코드 : 전체가능한경우의수 - 3이 하나도 없는 경우의수

n = int(input())

all = (n+1)*60*60

if n>3:
    k = n-1
else:
    k = n

no_3 = 45*45*(k+1)

answer = all-no_3

print(answer)

동빈나님 코드 : 가능한 모든시각의 경우를 하나씩 모두 세서 품 : 단순히 시각을 1씩 증가시키면서 3이 하나라도 포함되어있는지 확인

전체를 다해도 24*60*60 = 86,400가지는 많은경우의수가 아니므로 충분히 빠른시간에 탐색가능

예제문제3) 왕실의 나이트 ( 나이트가 갈수있는 곳의 경우의수)

내코드 : 움직일수있는 8가지를 행, 열로 배열로 만든뒤 포문돌려서 모두 움직여본후, 움직일때마다 칸을 벗어낫는지 확인  

리스트를 이용하여 방향벡터를 정의한다. ( 나이트가 이동할수 있는 8가지 방향 정의 dx, dy)

input = input()
n = input[0]
m = int(input[1])-1

list = ['a','b','c','d','e','f','g','h']

for i in range(len(list)):
    if n == list[i]:
        n = i

count = 0

dx = [1, -1, -2, -2, 1, -1, 2, 2]
dy = [2, 2, 1, -1, -2, -2, 1, -1]

for i in range(len(dx)):
    nx = m+dx[i]
    ny = n+dy[i]
    
    if nx <0 or nx>8 or ny <0 or ny>8:
        continue
    
    count += 1
    
print(count)

동빈나님 정답코드

예제문제4) 문자열 재정렬 : 알파벳은 오름차순으로정렬하여 출력하고, 그뒤로 모든 숫자를 더한값을 출력

내코드 : 주의,, 변수이름 str같은 쓰이는 이름으로 짓지말자

data = input()
count = 0
list = []
for i in data:
    if i.isdigit():
        count += int(i)
    else:
        list.append(i)
        

list.sort()

print(''.join(list)+str(count))

동빈나님 정답코드