Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Commit 889cb74

Browse files
Merge pull request #6 from chaerin-dev/chaerin-dev
2022年03月25日. Chaerin-dev 풀이 추가
2 parents 523fbc5 + 690fffd commit 889cb74

File tree

4 files changed

+135
-70
lines changed

4 files changed

+135
-70
lines changed

‎level-1/x만큼-간격이-있는-n개의-숫자.js‎

Lines changed: 18 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -2,9 +2,21 @@
22
//완벽한 정답이 아닙니다.
33
//정답 1 - codeisneverodd
44
function solution(x, n) {
5-
var answer = [];
6-
for (let i = 0; i < n; i++) {
7-
answer[i] = x * (i + 1)
8-
}
9-
return answer;
10-
}
5+
var answer = [];
6+
for (let i = 0; i < n; i++) {
7+
answer[i] = x * (i + 1);
8+
}
9+
return answer;
10+
}
11+
12+
//정답 2 - chaerin-dev
13+
function solution(x, n) {
14+
var answer = [];
15+
let add_gap = x;
16+
// n번 반복
17+
for (let i = 0; i < n; i++) {
18+
answer.push(x); // 처음 배열에 넣을 x
19+
x += add_gap; // x를 배열에 넣은 후 x값을 add_gap만큼 증가
20+
}
21+
return answer;
22+
}

‎level-1/완주하지-못한-선수.js‎

Lines changed: 70 additions & 50 deletions
Original file line numberDiff line numberDiff line change
@@ -2,64 +2,84 @@
22
//완벽한 정답이 아닙니다.
33
//정답 1 - codeisneverodd
44
function solution(participant, completion) {
5-
var answer = "";
6-
participant = participant.sort();
7-
completion = completion.sort();
8-
for (let i = 0, len = completion.length; i < len; i++) {
9-
if (participant[i] !== completion[i]) return participant[i];
10-
}
11-
answer = participant[participant.length - 1];
12-
return answer;
5+
var answer = "";
6+
participant = participant.sort();
7+
completion = completion.sort();
8+
for (let i = 0, len = completion.length; i < len; i++) {
9+
if (participant[i] !== completion[i]) return participant[i];
10+
}
11+
answer = participant[participant.length - 1];
12+
return answer;
1313
}
1414

1515
//정답 2 - jaewon1676
1616
function solution(participant, completion) {
17-
var answer = "";
18-
for (let i = 0; i < participant.length; i++) {
19-
for (let j = 0; j < completion.length; j++) {
20-
if (participant[i] === completion[j]) {
21-
console.log(participant, completion);
22-
participant.splice(i, 1);
23-
completion.splice(j, 1);
24-
i--;
25-
j--;
26-
console.log(participant, completion);
27-
break;
28-
}
29-
}
30-
}
17+
var answer = "";
18+
for (let i = 0; i < participant.length; i++) {
19+
for (let j = 0; j < completion.length; j++) {
20+
if (participant[i] === completion[j]) {
21+
console.log(participant, completion);
22+
participant.splice(i, 1);
23+
completion.splice(j, 1);
24+
i--;
25+
j--;
26+
console.log(participant, completion);
27+
break;
28+
}
29+
}
30+
}
3131

32-
return participant[0];
32+
return participant[0];
3333
}
3434

3535
//완벽한 정답이 아닙니다.
3636
//정답 3 - hyosung
3737
function solution(participant, completion) {
38-
let answer = "";
39-
// 2개 이상을 가진 특정값의 갯수 기록용 변수
40-
let max = 0;
41-
// 반복문 내부에서 set.has 를 사용하기 위해 Set 선언 (처음에는 Array.findIndex 를 사용)
42-
const set = new Set([...completion]);
43-
// 반복문 최적화 - 반복되던 연산 제거 (값 비교, length)
44-
const length = participant.length;
45-
for (let i = length; i--; ) {
46-
// 완주자 명단에 없다면 완주하지 못한 참가자 이므로 바로 종료
47-
if (!set.has(participant[i])) {
48-
answer = participant[i];
49-
break;
50-
}
51-
// 배열안에 특정값 갯수 확인
52-
let count = participant.reduce(
53-
(a, v) => (v === participant[i] ? a + 1 : a),
54-
0
55-
);
56-
// 해당 값이 참가자 그룹 내 2명 이상이고 이전 최대 동명이인 참가자보다 많다면
57-
// 해당 로직을 반복하면 제일 많은 동명이인을 알 수 있다
58-
if (count > 1 && max < count) {
59-
answer = participant[i];
60-
// 조건에 맞는 동명이인 수 저장
61-
max = count;
62-
}
63-
}
64-
return answer;
38+
let answer = "";
39+
// 2개 이상을 가진 특정값의 갯수 기록용 변수
40+
let max = 0;
41+
// 반복문 내부에서 set.has 를 사용하기 위해 Set 선언 (처음에는 Array.findIndex 를 사용)
42+
const set = new Set([...completion]);
43+
// 반복문 최적화 - 반복되던 연산 제거 (값 비교, length)
44+
const length = participant.length;
45+
for (let i = length; i--; ) {
46+
// 완주자 명단에 없다면 완주하지 못한 참가자 이므로 바로 종료
47+
if (!set.has(participant[i])) {
48+
answer = participant[i];
49+
break;
50+
}
51+
// 배열안에 특정값 갯수 확인
52+
let count = participant.reduce(
53+
(a, v) => (v === participant[i] ? a + 1 : a),
54+
0
55+
);
56+
// 해당 값이 참가자 그룹 내 2명 이상이고 이전 최대 동명이인 참가자보다 많다면
57+
// 해당 로직을 반복하면 제일 많은 동명이인을 알 수 있다
58+
if (count > 1 && max < count) {
59+
answer = participant[i];
60+
// 조건에 맞는 동명이인 수 저장
61+
max = count;
62+
}
63+
}
64+
return answer;
65+
}
66+
67+
//완벽한 정답이 아닙니다.
68+
//정답 4 - chaerin-dev
69+
function solution(participant, completion) {
70+
var answer = "";
71+
// 두 배열을 정렬한다!
72+
participant.sort();
73+
completion.sort();
74+
// 앞에서부터 차례로 비교하다가 값이 다를 때 participant의 요소가 완주하지 못한 선수!!
75+
// if (participant[i] != completion[i] || i == participant.length - 1) 이런 식으로
76+
// 완주하지 못한 선수의 이름이 마지막에 있을 경우도 고려해야 하나..? 라고 생각했지만
77+
// 그 때는 completion[i]의 값이 undefined가 되므로 괜찮음!
78+
for (let i = 0; i < participant.length; i++) {
79+
if (participant[i] != completion[i]) {
80+
answer = participant[i];
81+
break;
82+
}
83+
}
84+
return answer;
6585
}

‎level-1/직사각형-별찍기.js‎

Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,20 @@
1+
//https://github.com/codeisneverodd/programmers-coding-test
2+
//완벽한 정답이 아닙니다.
3+
//정답 1 - chaerin-dev
4+
process.stdin.setEncoding("utf8");
5+
process.stdin.on("data", (data) => {
6+
const n = data.split(" ");
7+
const a = Number(n[0]),
8+
b = Number(n[1]);
9+
// 정답을 저장할 문자열 answer
10+
answer = "";
11+
// 세로 길이만큼 아래의 과정(가로 길이만큼 별 더해주고 줄 바꾸기) 반복
12+
for (let i = 0; i < b; i++) {
13+
// 가로 길이만큼 문자열에 별 더해주기
14+
for (let j = 0; j < a; j++) answer += "*";
15+
// 가로 길이만큼 별을 다 더해줬으면 줄 바꾸기
16+
answer += "\n";
17+
}
18+
// 정답 출력
19+
console.log(answer);
20+
});

‎level-1/행렬의-덧셈.js‎

Lines changed: 27 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -2,23 +2,36 @@
22
//완벽한 정답이 아닙니다.
33
//정답 1 - codeisneverodd
44
function solution(arr1, arr2) {
5-
var answer = [];
6-
arr1.forEach((row, rowIndex) => {
7-
answer.push(row.map((col, colIndex) => col + arr2[rowIndex][colIndex]))
8-
})
9-
return answer;
5+
var answer = [];
6+
arr1.forEach((row, rowIndex) => {
7+
answer.push(row.map((col, colIndex) => col + arr2[rowIndex][colIndex]));
8+
});
9+
return answer;
1010
}
1111

1212
//정답 2 - codeisneverodd
1313
function solution(arr1, arr2) {
14-
var answer = new Array(arr1.length)
15-
for (let i = 0; i < arr1.length; i++) {
16-
answer[i] = new Array(arr1[0].length)
14+
var answer = new Array(arr1.length);
15+
for (let i = 0; i < arr1.length; i++) {
16+
answer[i] = new Array(arr1[0].length);
17+
}
18+
for (let row = 0; row < answer.length; row++) {
19+
for (let col = 0; col < answer[0].length; col++) {
20+
answer[row][col] = arr1[row][col] + arr2[row][col];
1721
}
18-
for (let row = 0; row < answer.length; row++) {
19-
for (let col = 0; col < answer[0].length; col++) {
20-
answer[row][col] = arr1[row][col] + arr2[row][col]
21-
}
22+
}
23+
return answer;
24+
}
25+
26+
//정답 3 - chaerin-dev
27+
function solution(arr1, arr2) {
28+
var answer = [];
29+
for (let i = 0; i < arr1.length; i++) {
30+
let ans_row = [];
31+
for (let j = 0; j < arr1[0].length; j++) {
32+
ans_row.push(arr1[i][j] + arr2[i][j]);
2233
}
23-
return answer;
24-
}
34+
answer.push(ans_row);
35+
}
36+
return answer;
37+
}

0 commit comments

Comments
(0)

AltStyle によって変換されたページ (->オリジナル) /