JavaScript | 백준 1330, 9498, 2753, 1026, 11656
프로그래머스에서 풀다가 node 환경 연습해보고자 풀어봄
input 아직 헷갈린다..
문제 : 1330 두 수 비교하기
두 정수 A와 B가 주어졌을 때, A와 B를 비교하는 프로그램을 작성하시오.
입력
첫째 줄에 A와 B가 주어진다. A와 B는 공백 한 칸으로 구분되어져 있다.
출력
첫째 줄에 다음 세 가지 중 하나를 출력한다.
- A가 B보다 큰 경우에는 '>'를 출력한다.
- A가 B보다 작은 경우에는 '<'를 출력한다.
- A와 B가 같은 경우에는 '=='를 출력한다.
const readline = require("readline");
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
rl.on("line", function(line){
input=line.split(" ")
let a =Number(input[0])
let b=Number(input[1])
if(a>b){
console.log('>')
}
else if (a<b){
console.log('<')
}
else{
console.log("==")
}
}).on("close", function(){
process.exit();
});
문제 : 9498 시험 성적
시험 점수를 입력받아 90 ~ 100점은 A, 80 ~ 89점은 B, 70 ~ 79점은 C, 60 ~ 69점은 D, 나머지 점수는 F를 출력하는 프로그램을 작성하시오.
입력
첫째 줄에 시험 점수가 주어진다. 시험 점수는 0보다 크거나 같고, 100보다 작거나 같은 정수이다.
출력
시험 성적을 출력한다.
const readline = require("readline");
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
let score=0
const onInput=(input)=> score=Number(input)
const onClose=()=>{
if(90<=score ){
console.log('A')
}else if(80<=score){
console.log('B')
}else if(70<=score){
console.log('C')
}else if(60<=score){
console.log('D')
}else{
console.log('F')
}
process.exit();
}
rl.on("line", onInput)
.on("close", onClose);
문제 : 2753 윤년
연도가 주어졌을 때, 윤년이면 1, 아니면 0을 출력하는 프로그램을 작성하시오.
윤년은 연도가 4의 배수이면서, 100의 배수가 아닐 때 또는 400의 배수일 때이다.
예를 들어, 2012년은 4의 배수이면서 100의 배수가 아니라서 윤년이다. 1900년은 100의 배수이고 400의 배수는 아니기 때문에 윤년이 아니다. 하지만, 2000년은 400의 배수이기 때문에 윤년이다.
입력
첫째 줄에 연도가 주어진다. 연도는 1보다 크거나 같고, 4000보다 작거나 같은 자연수이다.
출력
첫째 줄에 윤년이면 1, 아니면 0을 출력한다.
const readline = require("readline");
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
let year=0
const onInput=(input)=>year=Number(input)
const onClose=()=>{
if ((year%4==0&&year%100!=0)||(year%400==0)){
console.log(1)
}else{
console.log(0)
}
process.exit();
}
rl.on("line", onInput).on("close",onClose);
문제
흔한 수학 문제 중 하나는 주어진 점이 어느 사분면에 속하는지 알아내는 것이다. 사분면은 아래 그림처럼 1부터 4까지 번호를 갖는다. "Quadrant n"은 "제n사분면"이라는 뜻이다.

예를 들어, 좌표가 (12, 5)인 점 A는 x좌표와 y좌표가 모두 양수이므로 제1사분면에 속한다. 점 B는 x좌표가 음수이고 y좌표가 양수이므로 제2사분면에 속한다.
점의 좌표를 입력받아 그 점이 어느 사분면에 속하는지 알아내는 프로그램을 작성하시오. 단, x좌표와 y좌표는 모두 양수나 음수라고 가정한다.
입력
첫 줄에는 정수 x가 주어진다. (−1000 ≤ x ≤ 1000; x ≠ 0) 다음 줄에는 정수 y가 주어진다. (−1000 ≤ y ≤ 1000; y ≠ 0)
출력
점 (x, y)의 사분면 번호(1, 2, 3, 4 중 하나)를 출력한다.
const readline = require("readline");
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
let array=[]
rl.on("line",function(input){
array.push(Number(input))
}).on("close", function(){
const [x,y]=array
if(x>0&& y>0){
console.log('1')
}else if(x>0&&y<0){
console.log('4')
}else if(x<0&&y>0){
console.log('2')
}else if(x<0&&y<0){
console.log('3')
}
process.exit();
});
문제
대학생 새내기들의 90%는 자신이 반에서 평균은 넘는다고 생각한다. 당신은 그들에게 슬픈 진실을 알려줘야 한다.
입력
첫째 줄에는 테스트 케이스의 개수 C가 주어진다.
둘째 줄부터 각 테스트 케이스마다 학생의 수 N(1 ≤ N ≤ 1000, N은 정수)이 첫 수로 주어지고, 이어서 N명의 점수가 주어진다. 점수는 0보다 크거나 같고, 100보다 작거나 같은 정수이다.
출력
각 케이스마다 한 줄씩 평균을 넘는 학생들의 비율을 반올림하여 소수점 셋째 자리까지 출력한다.
예제 입력 1 복사
5
5 50 50 70 80 100
7 100 95 90 80 70 60 50
3 70 90 80
3 70 90 81
9 100 99 98 97 96 95 94 93 91
예제 출력 1 복사
40.000%
57.143%
33.333%
66.667%
55.556%
const readline = require("readline");
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
let input=[]
function onInput(line){
input.push(line)
}
rl.on("line", onInput).on("close", function () {
const num=Number(input[0])
for(let i=0;i<num;i++){
const nthArray=input[i+1].split(' ').map(Number)
const studentNum=nthArray[0]
let total=0;
let average=0;
let count=0;
let rate=0;
for(let j=1;j<nthArray.length;j++){
total+=nthArray[j]
}
average=total/studentNum;
for(let j=1;j<nthArray.length;j++){
if(nthArray[j]>average){
count++;
}
}
console.log((count/studentNum*100).toFixed(3)+"%")
}
process.exit();
});
문제 : 1026 보물
옛날 옛적에 수학이 항상 큰 골칫거리였던 나라가 있었다. 이 나라의 국왕 김지민은 다음과 같은 문제를 내고 큰 상금을 걸었다.
길이가 N인 정수 배열 A와 B가 있다. 다음과 같이 함수 S를 정의하자.
S = A[0] × B[0] + ... + A[N-1] × B[N-1]
S의 값을 가장 작게 만들기 위해 A의 수를 재배열하자. 단, B에 있는 수는 재배열하면 안 된다.
S의 최솟값을 출력하는 프로그램을 작성하시오.
입력
첫째 줄에 N이 주어진다. 둘째 줄에는 A에 있는 N개의 수가 순서대로 주어지고, 셋째 줄에는 B에 있는 수가 순서대로 주어진다. N은 50보다 작거나 같은 자연수이고, A와 B의 각 원소는 100보다 작거나 같은 음이 아닌 정수이다.
출력
첫째 줄에 S의 최솟값을 출력한다.
예제 입력 1 복사
5
1 1 1 6 0
2 7 8 3 1
예제 출력 1 복사
18
const readline = require("readline");
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
let input=[]
rl.on("line", function (x) {
input.push(x)
}).on("close", function () {
const num=Number(input[0])
const arrA=input[1].split(' ').map(Number)
const arrB=input[2].split(' ').map(Number)
arrA.sort((a,b)=>a-b)
arrB.sort((a,b)=>b-a)
let sum=0;
for (let i=0;i<num;i++){
sum+=arrA[i]*arrB[i]
}
console.log(sum)
process.exit();
});
sort(), sort().reverse()를 사용하니까 틀렸다고 뜬다
오름차순 .sort((a,b)=>a-b)
내림차순 .sort((a,b)=>b-a)
로 수정하니까 풀림.. 뭐지?
문제 : 3033 킹, 퀸, 룩, 비숍, 나이트, 폰
동혁이는 오래된 창고를 뒤지다가 낡은 체스판과 피스를 발견했다.
체스판의 먼지를 털어내고 걸레로 닦으니 그럭저럭 쓸만한 체스판이 되었다. 하지만, 검정색 피스는 모두 있었으나, 흰색 피스는 개수가 올바르지 않았다.
체스는 총 16개의 피스를 사용하며, 킹 1개, 퀸 1개, 룩 2개, 비숍 2개, 나이트 2개, 폰 8개로 구성되어 있다.
동혁이가 발견한 흰색 피스의 개수가 주어졌을 때, 몇 개를 더하거나 빼야 올바른 세트가 되는지 구하는 프로그램을 작성하시오.
입력
첫째 줄에 동혁이가 찾은 흰색 킹, 퀸, 룩, 비숍, 나이트, 폰의 개수가 주어진다. 이 값은 0보다 크거나 같고 10보다 작거나 같은 정수이다.
출력
첫째 줄에 입력에서 주어진 순서대로 몇 개의 피스를 더하거나 빼야 되는지를 출력한다. 만약 수가 양수라면 동혁이는 그 개수 만큼 피스를 더해야 하는 것이고, 음수라면 제거해야 하는 것이다.
예제 입력 1 복사
0 1 2 2 2 7
예제 출력 1 복사
1 0 0 0 0 1
const readline = require("readline");
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
let i=[]
rl.on("line", function (x) {
i.push(x)
}).on("close", function () {
const input=i[0].split(" ").map(Number)
console.log(1-input[0]);
console.log(1-input[1]);
console.log(2-input[2]);
console.log(2-input[3]);
console.log(2-input[4]);
console.log(8-input[5]);
process.exit();
});
문제 : 11656 접미사 배열
접미사 배열은 문자열 S의 모든 접미사를 사전순으로 정렬해 놓은 배열이다.
baekjoon의 접미사는 baekjoon, aekjoon, ekjoon, kjoon, joon, oon, on, n 으로 총 8가지가 있고, 이를 사전순으로 정렬하면, aekjoon, baekjoon, ekjoon, joon, kjoon, n, on, oon이 된다.
문자열 S가 주어졌을 때, 모든 접미사를 사전순으로 정렬한 다음 출력하는 프로그램을 작성하시오.
입력
첫째 줄에 문자열 S가 주어진다. S는 알파벳 소문자로만 이루어져 있고, 길이는 1,000보다 작거나 같다.
출력
첫째 줄부터 S의 접미사를 사전순으로 한 줄에 하나씩 출력한다.
예제 입력 1
baekjoon
예제 출력 1
aekjoon
baekjoon
ekjoon
joon
kjoon
n
on
oon
const readline = require("readline");
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
let input=[]
rl.on("line", function (x) {
input.push(x)
}).on("close", function () {
let inputStr=input[0]
let str=[]
for(let i=0;i<inputStr.length;i++){
str.push(inputStr.slice(i,inputStr.length));
}
let ans=str.sort().join("\n")
console.log(ans)
process.exit();
});
str.push() 할 때 파이썬이랑 헷갈려서 인덱싱사용했는데 그러면 안되구나..
js에서 문자열 자를 땐, slice 사용할것!
근데 처음엔 for문 한계값바꾸고 .slice(0,i+1)로 했는데..절케해야함
그리고 .join 활용하기!