본문 바로가기

알고리즘

(138)
[알고리즘] 백준 1932 정수 삼각형 / python, DP https://www.acmicpc.net/problem/1932 1932번: 정수 삼각형 문제 7 3 8 8 1 0 2 7 4 4 4 5 2 6 5 위 그림은 크기가 5인 정수 삼각형의 한 모습이다. 맨 위층 7부터 시작해서 아래에 있는 수 중 하나를 선택하여 아래층으로 내려올 때, 이제까지 선택된 수의 합이 최대가 되는 경로를 구하는 프로그램을 작성하라. 아래층에 있는 수는 현재 층에서 선택된 수의 대각선 왼쪽 또는 대각선 오른쪽에 있는 것 중에서만 선택할 수 있다. 삼각형의 크기는 1 이상 500 이하이다. 삼각형을 이루고 있는 각 수는 www.acmicpc.net import sys input = sys.stdin.readline #DP[i][j] : i, j에 도착했을때의 최댓값 N = int(..
[알고리즘] 백준 1120 문자열 / python https://www.acmicpc.net/problem/1120 1120번: 문자열 길이가 N으로 같은 문자열 X와 Y가 있을 때, 두 문자열 X와 Y의 차이는 X[i] ≠ Y[i]인 i의 개수이다. 예를 들어, X=”jimin”, Y=”minji”이면, 둘의 차이는 4이다. 두 문자열 A와 B가 주어진다. 이때, A의 길이는 B의 길이보다 작거나 같다. 이제 A의 길이가 B의 길이와 같아질 때 까지 다음과 같은 연산을 할 수 있다. A의 앞에 아무 알파벳이나 추가한다. A의 뒤에 아무 알파벳이나 추가한다. 이때, A와 B의 길이가 같으 www.acmicpc.net 입력이 adaabc aababbc 라면, 추가하는 아무 알파벳이 B와 같은거라고 가정하고 B의 인덱스를 옮겨가며 B의 길이 - A의 길이 ..
[알고리즘] 백준 1012 유기농 배추 / python https://www.acmicpc.net/problem/1012 1012번: 유기농 배추 차세대 영농인 한나는 강원도 고랭지에서 유기농 배추를 재배하기로 하였다. 농약을 쓰지 않고 배추를 재배하려면 배추를 해충으로부터 보호하는 것이 중요하기 때문에, 한나는 해충 방지에 효과적인 배추흰지렁이를 구입하기로 결심한다. 이 지렁이는 배추근처에 서식하며 해충을 잡아 먹음으로써 배추를 보호한다. 특히, 어떤 배추에 배추흰지렁이가 한 마리라도 살고 있으면 이 지렁이는 인접한 다른 배추로 이동할 수 있어, 그 배추들 역시 해충으로부터 보호받을 수 있다. ( www.acmicpc.net 재귀가 깊어서 런타임에러가 발생할 수 있으니 재귀깊이를 설정해주는 코드를 추가해줬다 배추가 있는곳에서 dfs함수를 호출해 상하좌우 배..
[알고리즘] 백준 16165 걸그룹 마스터 준석이 / python https://www.acmicpc.net/problem/16165 16165번: 걸그룹 마스터 준석이 정우는 소문난 걸그룹 덕후이다. 정우의 친구 준석이도 걸그룹을 좋아하지만 이름을 잘 외우지 못한다는 문제가 있었다. 정우는 친구를 위해 걸그룹 개인과 팀의 이름을 검색하여 외우게 하는 퀴즈 프로그램을 만들고자 한다. www.acmicpc.net N, M = map(int, input().split()) group = {} for i in range(N): g_name = input() member = int(input()) for j in range(member): m_name = input() group[g_name] = group.get(g_name, []) + [m_name] for i in ra..
[알고리즘] 백준 17389 보너스점수 / python https://www.acmicpc.net/problem/17389 17389번: 보너스 점수 숭고한 알고리즘 캠프 퀴즈 타임이 시작되었다! PS 기초, 동적 계획법, 파라메트릭 서치, 욱제의 생일, 탐색, 그리디, 최단경로 알고리즘, 구데기컵, 서로소 집합, 최소 신장 트리, 최소 공통 조상, 세그먼트 트리, 코드포스에서 C++로 높은 수준의 난수를 생성하는 방법, 최대 유량, 볼록 껍질, 스타트링크 사무실에 있는 게임용 컴퓨터의 RAM의 총 용량 등등 수많은 주제를 총망라하고 있는 이 미니 대회는 수많은 참가자들의 도전으로 오늘도 빛나고 있고, www.acmicpc.net N = int(input()) S = input() score, bonus = 0, 0 for i in range(N): if S..
[알고리즘] 백준 17269 이름궁합 테스트 / python https://www.acmicpc.net/problem/17269 17269번: 이름궁합 테스트 시윤이는 좋아하는 이성이 생기면 가장 먼저 이름궁합부터 본다. 이름궁합을 보는 방법은 간단하다. 먼저 이름을 알파벳 대문자로 적는다. 각 알파벳 대문자에는 다음과 같이 알파벳을 적는데 필요한 획수가 주어진다. 예를 들어, 두 사람의 이름인 LEESIYUN, MIYAWAKISAKURA 를 같이 표현했을 때 다음과 같이 먼저 주어진 이름부터 한 글자씩 적는다. 두 사람의 이름을 알파벳 대문자로 표현한 뒤, 한 글자씩 번갈아가며 적는다. 예시 : L M E www.acmicpc.net import copy dic = {'A':3,'B':2,'C':1,'D':2,'E':4,'F':3,'G':1,'H':3,'I':1..
[알고리즘] 프로그래머스 여행경로 / python https://programmers.co.kr/learn/courses/30/lessons/43164 코딩테스트 연습 - 여행경로 | 프로그래머스 [[ICN, SFO], [ICN, ATL], [SFO, ATL], [ATL, ICN], [ATL,SFO]] [ICN, ATL, ICN, SFO, ATL, SFO] programmers.co.kr 파이썬의 dictionary를 이용 ICN - SFO, ATL SFO - ICN 일 경우도 생각해서 코드를 짜야한다 def solution(tickets): routes = {} for i in tickets: routes[i[0]] = routes.get(i[0], []) + [i[1]] for j in routes: routes[j].sort(reverse=True..
[알고리즘] 프로그래머스 N으로 표현 / python https://programmers.co.kr/learn/courses/30/lessons/42895 코딩테스트 연습 - N으로 표현 | 프로그래머스 programmers.co.kr DP로 풀어내는 문제. 만약, N=5일때 arr[0] 👉 5 arr[1] 👉 55 , 5+5, 5-5, 5*5, 5//5 이런식으로 전개된다 5를 4번 사용한 경우(arr[3])를 생각해보면, arr[0] (+ - * //) arr[2] arr[1] (+ - * //) arr[1] arr[2] (+ - * //) arr[0] 에서 중복을 제거한 수들이 될것이다. def solution(N, number): arr = [set() for i in range(8)] for i, num in enumerate(arr, start=..