프로그래머스(Programmers)
-
모음사전 C++프로그래머스(Programmers) 2021. 10. 7. 00:26
#include #include #include using namespace std; vector collection = {'A', 'E', 'I', 'O', 'U'}; //모음 vector dic; //단어모음 void DFS(string word, int len) { if (len == word.length()) { dic.push_back(word); return; } for (int i=0; i DFS를 통해 다 만들어놓은 dic 벡터를 sort 함수를 사용해 정렬한다. => 처음부터 탐색하며 word를 찾았을 경우 return한다. https://codingham.tistory.com/168 DFS, BFS code =>BFS 와 DFS code를 사용하기 위해 미리 정리해두었습니다. //int..
-
상호 평가프로그래머스(Programmers) 2021. 9. 9. 22:36
제한사항 2 ≤ scores의 행의 길이(학생 수) ≤ 10 scores의 열의 길이 = scores의 행의 길이 즉, scores는 행과 열의 길이가 같은 2차원 배열입니다. 0 ≤ scores의 원소 ≤ 100 return 값 형식 0번 학생의 학점부터 차례대로 이어 붙인 하나의 문자열을 return 합니다. 입출력 예 scores result [[100,90,98,88,65],[50,45,99,85,77],[47,88,95,80,67],[61,57,100,80,65],[24,90,94,75,65]] "FBABD" [[50,90],[50,87]] "DA" [[70,49,90],[68,50,38],[73,31,100]] "CFD" #include #include #include #include usin..
-
부족한 금액 계산하기 C++프로그래머스(Programmers) 2021. 9. 7. 21:27
using namespace std; long long solution(int price, int money, int count) { long long answer = 0; for(int i=1; i 0) { answer = answer; } else { answer =0; } return answer; } => 주어진 조건대로 문제를 해결하면 되는 문제입니다. => 조건에 의해 answer는 int형을 벗어날 수 있으므로, int 형인 money에 해당 값이 들어가지 않도록 주의해야 합니다.
-
로또의 최고순위와 최저순위프로그래머스(Programmers) 2021. 9. 6. 23:09
#include #include using namespace std; vector solution(vector lottos, vector win_nums) { vector answer; int Win[7] = {6,6,5,4,3,2,1}; int cntZero=0; int cntMin=0; for(int i=0; i 안알려진 원소의 개수를 세어 cntZero에 넣습니다. => 당첨될 수 있는 최대수와 최저수를 계산하여 answer에 삽입합니다.
-
기능개발프로그래머스(Programmers) 2021. 9. 5. 22:00
#include #include using namespace std; vector solution(vector progresses, vector speeds) { vector answer; int last = progresses.size(); //3개 원소면 3리턴 int end = last; int cnt =0; int start =0; while(end > 0) { for(int i=0; i0) { answer.push_back(cnt); end -=cnt; cnt=0; } } } } return answer; } => progresses 배열에 speeds 배열의 수를 차례대로 더해 100이 넘는 배열을 찾습니다. => progresses 배열에 100이 넘은 배열이 있을 경우, 앞에서부터 차례로 ..
-
프로그래머스 - 탑 C++프로그래머스(Programmers) 2020. 7. 11. 14:21
문제 설명 수평 직선에 탑 N대를 세웠습니다. 모든 탑의 꼭대기에는 신호를 송/수신하는 장치를 설치했습니다. 발사한 신호는 신호를 보낸 탑보다 높은 탑에서만 수신합니다. 또한, 한 번 수신된 신호는 다른 탑으로 송신되지 않습니다. 예를 들어 높이가 6, 9, 5, 7, 4인 다섯 탑이 왼쪽으로 동시에 레이저 신호를 발사합니다. 그러면, 탑은 다음과 같이 신호를 주고받습니다. 높이가 4인 다섯 번째 탑에서 발사한 신호는 높이가 7인 네 번째 탑이 수신하고, 높이가 7인 네 번째 탑의 신호는 높이가 9인 두 번째 탑이, 높이가 5인 세 번째 탑의 신호도 높이가 9인 두 번째 탑이 수신합니다. 높이가 9인 두 번째 탑과 높이가 6인 첫 번째 탑이 보낸 레이저 신호는 어떤 탑에서도 수신할 수 없습니다. 맨 왼쪽..
-
프로그래머스 - 다리를 지나는 트럭 C++프로그래머스(Programmers) 2020. 7. 11. 11:34
문제 설명 트럭 여러 대가 강을 가로지르는 일 차선 다리를 정해진 순으로 건너려 합니다. 모든 트럭이 다리를 건너려면 최소 몇 초가 걸리는지 알아내야 합니다. 트럭은 1초에 1만큼 움직이며, 다리 길이는 bridge_length이고 다리는 무게 weight까지 견딥니다. ※ 트럭이 다리에 완전히 오르지 않은 경우, 이 트럭의 무게는 고려하지 않습니다. 예를 들어, 길이가 2이고 10kg 무게를 견디는 다리가 있습니다. 무게가 [7, 4, 5, 6] kg인 트럭이 순서대로 최단 시간 안에 다리를 건너려면 다음과 같이 건너야 합니다. 따라서, 모든 트럭이 다리를 지나려면 최소 8초가 걸립니다. solution 함수의 매개변수로 다리 길이 bridge_length, 다리가 견딜 수 있는 무게 weight, 트..
-
프로그래머스 - 전화번호 목록 C++프로그래머스(Programmers) 2020. 7. 11. 00:50
문제 설명 전화번호부에 적힌 전화번호 중, 한 번호가 다른 번호의 접두어인 경우가 있는지 확인하려 합니다. 전화번호가 다음과 같을 경우, 구조대 전화번호는 영석이의 전화번호의 접두사입니다. 구조대 : 119 박준영 : 97 674 223 지영석 : 11 9552 4421 전화번호부에 적힌 전화번호를 담은 배열 phone_book 이 solution 함수의 매개변수로 주어질 때, 어떤 번호가 다른 번호의 접두어인 경우가 있으면 false를 그렇지 않으면 true를 return 하도록 solution 함수를 작성해주세요. 제한사항 phone_book의 길이는 1 이상 1,000,000 이하입니다. 각 전화번호의 길이는 1 이상 20 이하입니다. 입출력 예 phone_book return [119, 97674..