Blue___
코딩배우는 학생🌎
Blue___
전체 방문자
오늘
어제
  • 코딩배우는 학생🧀 (242)
    • Algorithms (145)
      • BOJ[Java] (107)
      • Programmers[Java] (32)
      • Coding_Contest (3)
    • Web (22)
      • .NET Core C# (2)
      • Java (1)
      • Oracle SQL (7)
      • Web-ProJect (3)
      • Error처리 (1)
      • Web지식 (4)
      • Javascript (1)
      • Vue (3)
    • Git (4)
    • Java_beginner(Repl.it) (55)
      • Auto-Graded-Course(AP CS A) (54)
    • 프로젝트 직딩일기 (3)
    • Hanyang_Assignment (0)
    • 이모저모 (4)
      • 잡담 (1)
      • 2021 오픈소스 컨트리뷰터 아카데미 (1)
      • DDD - 6기! (1)
    • 북리뷰 (1)
      • 리팩토링 2판 (1)
      • 클린코드 (0)

블로그 메뉴

  • 🐰GITHUB
  • ☘️포트폴리오
  • 🌸MBC개발_투표 2022
  • 🍭MBC_APP

공지사항

인기 글

태그

  • 자바
  • AP CS A
  • coding
  • auto-graded course
  • 알고리즘
  • 프로그래머스
  • Java tutorial
  • programmers
  • 레플릿
  • 코딩배우는학생
  • 코딩배우는 학생
  • 백준
  • java basic
  • algorithm
  • Bakjoon
  • 프로그래밍
  • repl.it
  • REPL
  • 코딩
  • Java

최근 댓글

최근 글

티스토리

hELLO
Blue___

코딩배우는 학생🌎

[Bakjoon/2577번] 숫자의 개수[Java]
Algorithms

[Bakjoon/2577번] 숫자의 개수[Java]

2019. 11. 27. 01:16

아래 포스팅을 통해 문제를 확인할 수 있습니다!!

https://www.acmicpc.net/problem/2577

 

2577번: 숫자의 개수

첫째 줄에 A, 둘째 줄에 B, 셋째 줄에 C가 주어진다. A, B, C는 모두 100보다 같거나 크고, 1,000보다 작은 자연수이다.

www.acmicpc.net

 

문제

 

세 개의 자연수 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까지의 숫자가 각각 몇 번 쓰였는지 차례로 한 줄에 하나씩 출력한다.

 


풀이

 

import java.util.*;

public class Main {
	public static void main(String[] args) {
		Scanner sc =new Scanner(System.in);	
		int A=sc.nextInt();
		int B=sc.nextInt();
		int C=sc.nextInt();
		int cnt=0;
		
		int mul = A*B*C;
		int [] array =new int[10];
		
		while(mul>0) {
			array[mul%10]+=1;
			mul/=10;
		}
		for(int i=0;i<10;i++) {
			System.out.println(array[i]);
		}
	}
}

배열의 위치값과 위치값에 따른 값이 같기때문에 위치값에 해당하는 값이 있을때마다 반복문으로 +=1씩 해주면되는 문제입니다. 

1의 자리부터 하나씩 계산하고 /10으로 mul값에서 쓴 값은 제거합니다.

반응형
저작자표시 (새창열림)

'Algorithms' 카테고리의 다른 글

[Recursion]재귀: 미로찾기 C#  (0) 2021.03.09
[Recursion:Backtracking, 깊이우선 탐색 예제] N-Queen C#  (0) 2021.03.09
    'Algorithms' 카테고리의 다른 글
    • [Recursion]재귀: 미로찾기 C#
    • [Recursion:Backtracking, 깊이우선 탐색 예제] N-Queen C#
    Blue___
    Blue___
    완전 연소한 불은 재를 남기지않는다 : 코딩배우는학생 🌎

    티스토리툴바