티스토리 뷰
문제
세 개의 자연수 A, B, C가 주어질 때 A × B × C를 계산한 결과에 0부터 9까지 각각의 숫자가 몇 번씩 쓰였는지를 구하는 프로그램을 작성하시오.
예를 들어 A = 150, B = 266, C = 427 이라면 A × B × C = 150 × 266 × 427 = 17037300 이 되고, 계산한 결과 17037300 에는 0이 3번, 1이 1번, 3이 2번, 7이 2번 쓰였다.
입력
첫째 줄에 A, 둘째 줄에 B, 셋째 줄에 C가 주어진다. A, B, C는 모두 100보다 크거나 같고, 1,000보다 작은 자연수이다.
출력
첫째 줄에는 A × B × C의 결과에 0 이 몇 번 쓰였는지 출력한다. 마찬가지로 둘째 줄부터 열 번째 줄까지 A × B × C의 결과에 1부터 9까지의 숫자가 각각 몇 번 쓰였는지 차례로 한 줄에 하나씩 출력한다.
예제입력
150
266
427
예제 출력
3
1
0
2
0
0
0
2
0
0
문제풀이
//입력값 받기, 같은 폴더내에 input.txt 생성
const fs = require('fs');
const filePath = process.platform === 'linux' ? '/dev/stdin' : './input.txt';
let input = fs.readFileSync(filePath).toString().split('\n');
solution(input);
function solution(input) {
let num = input[0] * input[1] * input[2];
let array = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0];
let result = '';
for (let i = 0; i < (num + '').length; i++) {
switch ((num + '')[i]) {
case '0':
array[0]++;
break;
case '1':
array[1]++;
break;
case '2':
array[2]++;
break;
case '3':
array[3]++;
break;
case '4':
array[4]++;
break;
case '5':
array[5]++;
break;
case '6':
array[6]++;
break;
case '7':
array[7]++;
break;
case '8':
array[8]++;
break;
case '9':
array[9]++;
break;
default:
'';
}
}
for (let i = 0; i < array.length; i++) {
result += array[i] + '\n';
}
console.log(result);
}
설명
문자열로 입력받은 값은 * 연산자를 통해 암묵적 형 변환이 되어 Number 형으로 변환되어 정상적으로 * 연산이 진행됨.
곱 연산 진행 후, 숫자를 칸마다 나눠서 비교하기 위해 문자열로 변환. (num +'')
0~9까지 숫자 count를 저장하기 위한 array를 기본값은 0으로 생성
Switch문을 사용하여 각 케이스에 맞게 값을 증가시킴.
하단의 반복문은 출력 결과를 맞추기 위해 진행.
출처
https://www.acmicpc.net/problem/2577
2577번: 숫자의 개수
첫째 줄에 A, 둘째 줄에 B, 셋째 줄에 C가 주어진다. A, B, C는 모두 100보다 크거나 같고, 1,000보다 작은 자연수이다.
www.acmicpc.net
'Algorithm' 카테고리의 다른 글
[JavaScript ] BeakJoon 4673 셀프 넘버 (0) | 2021.08.24 |
---|---|
[JavaScript ] BeakJoon 3052 나머지 (0) | 2021.08.15 |
[JavaScript ] BeakJoon 1110 더하기 사이클 (0) | 2021.08.14 |
[JavaScript ] BeakJoon 15552 빠른 A+B (0) | 2021.08.06 |
[JavaScript ] BeakJoon 2884 알람시계 (0) | 2021.08.04 |
- Total
- Today
- Yesterday
- JavaScript #Programmers #lvl2 #프로그래머스 오픈채팅방 # 오픈채팅방 문제
- Swal #sweetalert2 #alert #알림창 띄우기 #react swal
- AWS #인바운드 #SSH #인스턴스 연결
- mysql date type
- PoolCluster : Error: connect ECONNREFUSED 127.0.0.1:3306)
- node.js 파일 저장
- node.js #node.js pdf만들기 #node.js pdfkit
- supported: linux/amd64
- linux/amd64/v2
- React filter #js Includes #React Filter includes
- react #img 전송
- Mac docker.for.mac.host.internal
- react #react-spinners #modal loading #overlay #로딩창 #react 로딩창 만들기
- ec2 instance connect is unable to connect to your instance. ensure your instance network settings are configured correctly for ec2 instance connect. for more information
- Pytorch #Yolov5 #Segementation
- Express multer #Express File 저장 #node.js
- excel 파일 만들기 #node.js #express excel 파일 만들기 #데이터 입력해서 excel 파일 만들기
- ERROR: failed to solve: no support for running processes with linux/amd64/v3 platform
- mysql date
- see ec2 instance connect prerequisites at https://docs.aws.amazon.com/awsec2/latest/userguide #인스턴스 연결 안됨
- FormData #FormData 파일전송 #FormData append json # React FormData File #React FormData append Json
- 이미지 전송 # 이미지 업로드 #이미지 여러장 #이미지 여러장 업로드 #react 이미지 업로드 #react 이미지 여러장 업로드
- docker # docker build # m1 docker build
- Procedure #mysql #mysql Procedure #mysql 반복문 #Procedure 반복문 #mysql insert 반복문
- PDF #pdfkit
- mysql date between # mysql date between 대소 비교 연산자
- mysql date between performance
- docker mysql
- BOJ #JS
- reack-cookies #아이디 저장하기 #react 아이디 저장 #react cookie #리엑트 아이디 저장하기
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |