• [백준/JAVA] 2577번 숫자의 개수

    2021. 10. 3.

    by. 하루플스토리

    반응형

    안녕하세요, 하루플입니다.

    이번에도 이중 for문으로 풀 수 있는 문제를 가져왔습니다.

     

    문제

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


    처음에 음? 쉽겠군 하고 for문 하나로 풀리는 문제인가 했는데 0~9 숫자 검사를 위한 i와 각 자리를 비교할 j를 사용해야해서 2중 for문을 사용해야 했습니다. 문제 자체는 어렵지 않았지만 조심해야할 부분이 있습니다.

     

     

    바로 charAt 인데요. charAt을 사용할 때 단순히 int 형과 비교를 하면 아스키코드로 비교하게 됩니다.

    그래서 str.charAt(j) - '0' 이나 str.charAt(j) - 48 을 꼭 해주어야합니다.

     

    문제는 풀었는데 다음엔 시간을 더 단축할 수 있는 알고리즘으로 풀어봐야겠습니다!

    반응형

    댓글