목록2022/05/05 (15)
치춘짱베리굿나이스
부분수열의 합 문제 N개의 정수로 이루어진 수열이 있을 때, 크기가 양수인 부분수열 중에서 그 수열의 원소를 다 더한 값이 S가 되는 경우의 수를 구하는 프로그램을 작성하시오. 입력 첫째 줄에 정수의 개수를 나타내는 N과 정수 S가 주어진다. (1 ≤ N ≤ 20, |S| ≤ 1,000,000) 둘째 줄에 N개의 정수가 빈 칸을 사이에 두고 주어진다. 주어지는 정수의 절댓값은 100,000을 넘지 않는다. 출력 첫째 줄에 합이 S가 되는 부분수열의 개수를 출력한다. 풀이 let ans = 0; let n; let s; const recurSeq = (input, k, sum) => { if (k === n && sum === s) ans++; if (k === n) return; recurSeq(inpu..
N과 M (1) 문제 자연수 N과 M이 주어졌을 때, 아래 조건을 만족하는 길이가 M인 수열을 모두 구하는 프로그램을 작성하시오. 1부터 N까지 자연수 중에서 중복 없이 M개를 고른 수열 입력 첫째 줄에 자연수 N과 M이 주어진다. (1 ≤ M ≤ N ≤ 8) 출력 한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해야 한다. 풀이 let arr; const recurNandM = (n, m, k, isUsed, ans) => { if (k === m) ans.push(arr.join(" ")); else { for (let i = 1; i { let [n, m] = re..
회사에 있는 사람 문제 상근이는 세계적인 소프트웨어 회사 기글에서 일한다. 이 회사의 가장 큰 특징은 자유로운 출퇴근 시간이다. 따라서, 직원들은 반드시 9시부터 6시까지 회사에 있지 않아도 된다. 각 직원은 자기가 원할 때 출근할 수 있고, 아무때나 퇴근할 수 있다. 상근이는 모든 사람의 출입카드 시스템의 로그를 가지고 있다. 이 로그는 어떤 사람이 회사에 들어왔는지, 나갔는지가 기록되어져 있다. 로그가 주어졌을 때, 현재 회사에 있는 모든 사람을 구하는 프로그램을 작성하시오. 입력 첫째 줄에 로그에 기록된 출입 기록의 수 n이 주어진다. (2 ≤ n ≤ 106) 다음 n개의 줄에는 출입 기록이 순서대로 주어지며, 각 사람의 이름이 주어지고 "enter"나 "leave"가 주어진다. "enter"인 경..
РАВЕНСТВО 문제 Учителката по математика дала на учениците да намерят неизвестното x от равенството: a·x = b-c. Числата а, b и c са естествени числа и са такива, че решението x е цяло число. Знайко посещавал школата по информатика и опитал да направи програма, но се затруднил. Помогнете му, като напишете програма equation, която намира неизвестното x. 입력 На първия ред на стандартния вход се задават..
엄청난 부자2 문제 갑부 최백준 조교는 동전을 최소로 바꾸는데 성공했으나 김재홍 조교가 그 돈을 발견해서 최백준 조교에게 그 돈을 나누자고 따진다. 그 사실이 전 우주로 알려지자 우주에 있던 많은 생명체들이 자신들에게 돈을 분배해 달라고 당장 달려오기 시작했다. 프로토스 중앙 우주 정부의 정책인, ‘모든 지적 생명체는 동등하다’라는 규칙에 입각해서 돈을 똑같이 분배하고자 한다. 한 생명체에게 얼마씩 돈을 줄 수 있는가? 또, 생명체들에게 동일하게 분배한 후 남는 돈은 얼마인가? 입력 첫째 줄에는 최백준 조교가 가진 돈 n과 돈을 받으러 온 생명체의 수 m이 주어진다. (1 ≤ m ≤ n ≤ 101000, m과 n은 10진수 정수) 출력 첫째 줄에 생명체 하나에게 돌아가는 돈의 양을 출력한다. 그리고 두 ..
팀빌딩 공식적인 내생각 총 9명 지금까지 작업해본 프로젝트 팀 중 프론트엔드 인원이 가장 많았던 게 최대 6명이었는데 (그마저도 얼마 안되어 3명으로 줄었다) 9명... 처음겪어보는 팀원수였다 인원이 많은 만큼 역할분담이나 팀원간 작업흐름이 원활히 공유되어야 할 것 같다 프리온보딩 전까지 별도의 프로젝트를 진행하면서 작업내용을 공유하지 않는 팀원, 소통이 안되는 팀원, 중구난방으로 정리되는 스케줄, 아무도 모르게 흐지부지되는 프로젝트... 등을 겪고 나니까 각성한 기분이다 마치 레드불로 샤워를 한듯한 기분 ... 이런저런 팀에 몸담아 보니 결론은 어떤 팀에서든 Github 기능을 최대한 이용하여 (Issue, Pull Request, Kanban Board, Wiki 등...) 보기좋은 Organizat..
Github Wiki 위키를 왜 만들까요 나 같은 경우엔 노션을 따로 정리하더라도 깃허브에 더 자주 들르게 되고, 따라서 깃허브에 최대한 할 일이나 각종 문서들을 저장하는 것이 좋겠다는 생각이 들었다 팀 노션 들어가있는 곳도 워낙 많고... 코딩 컨벤션과 같이 자주 체크해야 하는 항목들은 깃허브에 붙여놓는 것이 훨씬 좋겠다는 생각이 들어 위키를 작성해두게 되었다 위키 생성하기 프라이빗 레포의 위키 생성은 아쉽게도 유료이다 (단발성 프로젝트에서 돈을 내기엔 애매하다..) 어차피 나중에 채점을 진행해야 하니 퍼블릭으로 돌려놓으면 Wikis 항목을 활성화할 수 있다 Wikis 항목의 체크박스를 체크해 활성화시키면 레포지토리의 상단에 Wiki 탭이 생긴다 와~ 위키가 생겼다 첫 페이지가 자동으로 생성된다 페이지..