-
Notifications
You must be signed in to change notification settings - Fork 0
/
67_.js
65 lines (53 loc) · 1.77 KB
/
67_.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/*
문제67 : 민규의 악수
광장에서 모인 사람들과 악수를 하는 행사가 열렸습니다.
참가자인 민규는 몇명의 사람들과 악수를 한 후 중간에 일이 생겨 집으로 갔습니다.
이 행사에서 진행된 악수는 총 n번이라고 했을 때,
민규는 몇 번의 악수를 하고 집으로 돌아갔을까요?
그리고 민규를 포함한 행사 참가자는 몇 명일까요?
- 악수는 모두 1대 1로 진행이 됩니다.
- 민규를 제외한 모든 참가자는 자신을 제외한 참가자와 모두 한번씩 악수를 합니다.
- 같은 상대와 중복된 악수는 카운트 하지 않습니다.
- 민규를 제외한 참가자는 행사를 모두 마쳤습니다.
예를들어 행사에서 59회의 악수가 진행되었다면 민규는 4번의 악수를 하였고 민규를 포함한 참가자는 12명이다.
행사에서 진행된 악수 횟수(n)를 입력으로 받으면 민규의 악수 횟수와 행사 참가자 수가 출력됩니다.
**입력**
59
**출력**
[4, 12] //[악수 횟수, 행사 참가자 수]
*/
// 답안
function solution(number) {
let 사람 = 0;
let 총악수 = 0;
let temp = 0;
while (true) {
총악수 = parseInt((사람 * (사람 - 1)) / 2, 10);
if (n < 총악수) {
break;
}
temp = 총악수;
사람 += 1;
}
return [parseInt(n - temp, 10), 사람];
}
const 악수의수 = 59;
console.log(solution(악수의수));
// const 참가자 = ["a", "b", "c", "d"];
// 입력 : 59
// (n-1)n/2
// 10* 11 /2 (11명 참가자일 때 55)
// 민규가 4번의 악수
// 3
// [a,b]
// [a,c]
// [a,d]
// 2
// [b,c]
// [b,d]
// 1
// [c,d]
// 참가자 ==n + 1(민규)
// 악수의 수 = n-1 + n+2 + n+3 ... 1
// 100 + 99 + 98 + ... + 3 + 2 + 1 ==101*50 = 5050
// n(n+1)/2 => (n-1)n/2