문제
삼각형의 세 변의 길이가 주어질 때 변의 길이에 따라 다음과 같이 정의한다.
- Equilateral : 세 변의 길이가 모두 같은 경우
- Isosceles : 두 변의 길이만 같은 경우
- Scalene : 세 변의 길이가 모두 다른 경우
단 주어진 세 변의 길이가 삼각형의 조건을 만족하지 못하는 경우에는 "Invalid" 를 출력한다. 예를 들어 6, 3, 2가 이 경우에 해당한다. 가장 긴 변의 길이보다 나머지 두 변의 길이의 합이 길지 않으면 삼각형의 조건을 만족하지 못한다.
세 변의 길이가 주어질 때 위 정의에 따른 결과를 출력하시오.
입력
각 줄에는 1,000을 넘지 않는 양의 정수 3개가 입력된다. 마지막 줄은 0 0 0이며 이 줄은 계산하지 않는다.
출력
각 입력에 맞는 결과 (Equilateral, Isosceles, Scalene, Invalid) 를 출력하시오.
예제 입력
7 7 7
6 5 4
3 2 5
6 2 6
0 0 0
예체 출력
Equilateral
Scalene
Invalid
Isosceles
바보같이 삽질했던 코드🤯
let fs=require('fs');
let input=fs.readFileSync('/dev/stdin').toString().split('\n');
for(let i=0; i<(input.length)-1;i++){
let [a,b,c]=input[i].split(' ').map((n)=>Number(n));
let n=[a,b,c]
let max=Math.max(a,b,c);
let other=n.filter(v=>v!==max);
if(max>=(other[0]+other[1])){
console.log('Invalid');
}else{
if(a===b&&b===c){
console.log('Equilateral')
}else if(a!==b&&a!==c&&b!==c){
console.log('Scalene');
}else{
console.log('Isosceles')
}
}
}
최댓값에만 집중하고 같은 값이 두개 있을 경우를 고려하지 않았다. 한 마디로 위 코드로 하면 other 배열에 값이 하나만 존재할 수도 있다는 것이다.....
최종 코드
let fs=require('fs');
let input=fs.readFileSync('/dev/stdin').toString().trim().split('\n');
input.pop()
for(let i=0; i<input.length;i++){
let [a,b,c]=input[i].split(' ').map((n)=>Number(n));
let sort=[a,b,c].sort((x,y)=>x-y);
let [x,y,z]=sort;
if(z>=x+y){
console.log('Invalid');
}else{
if(x===y&&y===z){
console.log('Equilateral')
}else if(x!==y&&x!==z&&y!==z){
console.log('Scalene');
}else{
console.log('Isosceles')
}
}
}
sort를 이용해서 제일 큰 값을 뒤로 보내서 오름차순으로 값들을 정렬했다. 그리고 나서 합과 max 값을 비교하는 방식으로 코드를 수정했다. 근데 이것만 수정했을 때 계속 틀렸다고 떠서 왜일까 계속 찾아보다가 input에 trim을 넣으니까 됐다...ㅠㅠㅠㅠ
trim() 메서드는 문자열의 양 끝에 있는 공백 문자를 제거하는 기능을 하는데, input에 불필요한 공백이 있었던거 같다...하하
'Algorithm🐙 > BaekJoon' 카테고리의 다른 글
[백준] 2231번: 분해합 -JS (0) | 2024.08.20 |
---|---|
[백준] 11005번: 진법 변화2 -JS (0) | 2024.07.07 |
[백준] 2563번: 색종이 -JS (0) | 2024.07.03 |
[백준] 1157번: 단어 공부 -JS (0) | 2024.07.01 |
[백준] 3003번: 킹, 퀸, 룩, 비숍, 나이트, 폰 -JS (0) | 2024.06.25 |