과제
자료를 저장 할 수 있고, 조건문으로 제어 할 수 있고, 반복할 수 있다면..
Last updated
자료를 저장 할 수 있고, 조건문으로 제어 할 수 있고, 반복할 수 있다면..
Last updated
가 아니라.. 우리가 배운 것들을 활용해보는 관점에서 진행하는 과제입니다.
사실 코딩테스트 문제를 풀기 위해서는 더 알아야 할 것들이 많습니다. 자료구조와 알고리즘도 알아야 하고, 구현 관련해서 문자열 관련 메서드들이나, 유용하게 사용 할 수 있는 기타 함수들을 잘 알고 있어야 구현을 할 수 있습니다. 하지만 이러한 모든 "지식"들은 앞으로 배워 나갈 시간이 매우 충분합니다. 오늘은 그러한 "지식"들에 의존하지 않고도 스스로 구현 가능하다는 것을 배워보는 시간이 됐으면 좋겠습니다.
사실 프로그래밍 문법에서 가장 중요한 것 두가지를 꼽으라고 하면, 조건문과 반복문 일 것이고, 한가지를 꼽으라고 하면 반복문일 것 입니다. 프로그래밍을 하는 본질적인 이유는 컴퓨터에게 "일"을 시키는 것 이고, 그 "일"은 사람이 할 수 없는 대단한 일이 아닌, 단순 반복 작업 입니다. 그래서 조금 과장을 섞으면, 조건문과 반복문만 알면 기본적으로 모든 프로그램을 만들 수 있다고들 이야기 합니다. 이러한 관점에서 오늘 문제를 접근하겠습니다.
위 링크를 들어가보시면 아시겠지만, 들어가보면 뭔가 읽기 싫은 글과, 우측에 위의 그림과 같이 solution이라고 이름지어진 함수가 보이실 겁니다. 물론 우리가 함수를 제대로 다시 공부하지는 않았지만, 일반적으로 여러분이 잠깐 잠깐 배운 바로도 solution이라는 함수이며, sizes라는 것을 파라미터로 받는다는 것 정도는 알고 계실겁니다. 가장 대표적으로 파이썬에서의 함수와 비슷하게 생겼죠.
코딩테스트를 진행하면 보통 다음과 같이 이름이 정해진 solution 함수와, sizes와 같이 해당 함수의 파라미터로 전달하는 input, answer와 같이 원하는 output을 명시해둡니다. 우리는 그 해당하는 함수의 중간을 구현하면 됩니다.
우리가 풀어야 할 문제는 다음과 같이 생겼네요.
명함 지갑을 만드는 회사에서 지갑의 크기를 정하려고 합니다. 다양한 모양과 크기의 명함들을 모두 수납할 수 있으면서, 작아서 들고 다니기 편한 지갑을 만들어야 합니다. 이러한 요건을 만족하는 지갑을 만들기 위해 디자인팀은 모든 명함의 가로 길이와 세로 길이를 조사했습니다.
아래 표는 4가지 명함의 가로 길이와 세로 길이를 나타냅니다.
1
60
50
2
30
70
3
60
30
4
80
40
가장 긴 가로 길이와 세로 길이가 각각 80, 70이기 때문에 80(가로) x 70(세로) 크기의 지갑을 만들면 모든 명함들을 수납할 수 있습니다. 하지만 2번 명함을 가로로 눕혀 수납한다면 80(가로) x 50(세로) 크기의 지갑으로 모든 명함들을 수납할 수 있습니다. 이때의 지갑 크기는 4000(=80 x 50)입니다.
모든 명함의 가로 길이와 세로 길이를 나타내는 2차원 배열 sizes가 매개변수로 주어집니다. 모든 명함을 수납할 수 있는 가장 작은 지갑을 만들 때, 지갑의 크기를 return 하도록 solution 함수를 완성해주세요.
제한사항
sizes의 길이는 1 이상 10,000 이하입니다.
sizes의 원소는 [w, h] 형식입니다.
w는 명함의 가로 길이를 나타냅니다.
h는 명함의 세로 길이를 나타냅니다.
w와 h는 1 이상 1,000 이하인 자연수입니다.
입출력 예
[[60, 50], [30, 70], [60, 30], [80, 40]]
4000
[[10, 7], [12, 3], [8, 15], [14, 7], [5, 15]]
120
[[14, 4], [19, 6], [6, 16], [18, 7], [7, 11]]
133
🤔 : 천천히 문제를 읽어보세요, 그리고 이해가 가지 않는다면, 입출력 예를 보면 훨씬 수월할 때가 많습니다. 배열이 들어있는 배열을 받는데 그건 가로,세로 길이를 나타내고, 그 배열은 위에 solution함수의 parameter로 들어갑니다. 그리고 우리가 만들어낼 지갑의 가로 세로 길이를 곱해서 answer에 넣어주면 된다고 합니다. 그럼 우리는 저 배열을 받아서 리턴해줄 가로길이와 세로길이만 구하면 되겠네요! 이 이야기가 이해가 가지 않는다면 조금 더 천천히 읽어봐주세요! 어떻게 풀지는 제가 아래에서 설명해드릴 예정이니, 이 단락의 내용만 이해해주시면 될 것 같습니다.
요구사항에서는 모든 명함이 다 들어가야한다, 명함을 '회전'해야 한다 와 같은 내용으로 우리를 현혹시키고 있지만, 우리는 데이터를 조금 더 들여다보면 전혀 그렇게 귀찮은 짓을 하지 않아도 된다는 것을 알 수 있습니다.
두 변 길이가 하나의 배열로 들어오는데, 정사각형이 아니므로 그 두 변은 분명히 작은 변, 긴 변으로 나눌 수 있을겁니다. 그 두 변 길이중 작은 변 중에 가장 긴 변, 그리고 긴 변중에 가장 긴변을 구해주면 되겠죠?
보통 코딩테스트에는 일정한 테크닉들이 있습니다. 이런 것들은 많이 풀어가면서 다른 사람의 풀이를 보거나 배워가면 자연스럽게 체득이 됩니다. 하지만 지금 당장 아주 잠시동안의 여러분들은 이러한 것들을 알지 못하실 거에요. 그래서 이 아이디어도 알려드리겠습니다.
기본적으로 아래와 같은 흐름으로 풀어가시면 됩니다. 물론 더 편하게 할 수 있는 방법이 있겠지만, 지금은 일단 for 문과 if문만 사용하도록 합니다!
문제 설명
문자열로 구성된 리스트 strings와, 정수 n이 주어졌을 때, 각 문자열의 인덱스 n번째 글자를 기준으로 오름차순 정렬하려 합니다. 예를 들어 strings가 ["sun", "bed", "car"]이고 n이 1이면 각 단어의 인덱스 1의 문자 "u", "e", "a"로 strings를 정렬합니다.
제한 조건
strings는 길이 1 이상, 50이하인 배열입니다.
strings의 원소는 소문자 알파벳으로 이루어져 있습니다.
strings의 원소는 길이 1 이상, 100이하인 문자열입니다.
모든 strings의 원소의 길이는 n보다 큽니다.
인덱스 1의 문자가 같은 문자열이 여럿 일 경우, 사전순으로 앞선 문자열이 앞쪽에 위치합니다.
입출력 예
["sun", "bed", "car"]
1
["car", "bed", "sun"]
["abce", "abcd", "cdx"]
2
["abcd", "abce", "cdx"]
입출력 예 설명
입출력 예 1 "sun", "bed", "car"의 1번째 인덱스 값은 각각 "u", "e", "a" 입니다. 이를 기준으로 strings를 정렬하면 ["car", "bed", "sun"] 입니다.
입출력 예 2 "abce"와 "abcd", "cdx"의 2번째 인덱스 값은 "c", "c", "x"입니다. 따라서 정렬 후에는 "cdx"가 가장 뒤에 위치합니다. "abce"와 "abcd"는 사전순으로 정렬하면 "abcd"가 우선하므로, 답은 ["abcd", "abce", "cdx"] 입니다.
문제 자체에 대한 이해는 빠르게 하셨을 것 같습니다. 오늘은 문제 설명과 관련한 내용은 필요 없겠죠?
당연히 정렬하는 부분은 여러분이 구현을 하셔야 합니다!
사전식으로 정렬하면 됩니다!
근데 인덱스에 해당하는 문자열을 해당하는 단어 앞에 붙여서 정렬하면 한큐에 끝나겠네요!
그렇다면
문자열 앞에 인덱스에 해당하는 문자를 붙인다
사전순으로 정렬한다
정렬된 배열의 가장 앞 글자를 땐다
이렇게 풀어낼 수 있겠네요.