본문 바로가기

Algorithm judge/Backjoon

[1316번] 백준 그룹 단어 체커 - 자바

문제

 

그룹 단어란 단어에 존재하는 모든 문자에 대해서, 각 문자가 연속해서 나타나는 경우만을 말한다. 예를 들면, ccazzzzbb는 c, a, z, b가 모두 연속해서 나타나고, kin도 k, i, n이 연속해서 나타나기 때문에 그룹 단어이지만, aabbbccb는 b가 떨어져서 나타나기 때문에 그룹 단어가 아니다.

 

단어 N개를 입력으로 받아 그룹 단어의 개수를 출력하는 프로그램을 작성하시오.

 

문제 해설

 

  • ccbbdd는 각 문자가 연속하여 나타나기에 이는 하나의 '그룹 단어'이다.
  • 만약 입력되는 단어가 3개라 하였을 때,

    apple
    banana
    carot

    apple과 carot은 각 문자들이 연속하여 나타나 그룹단어이나, banana는 a가 단어 내에서 연속해서 나타나지 않아 이는 그룹단어가 아니다. 

    고로 위 단어들이 입력 값으로 주어졌을 때, 결괏값은 2이다.

입력

 

첫째 줄에 단어의 개수 N이 들어온다. N은 100보다 작거나 같은 자연수이다. 둘째 줄부터 N개의 줄에 단어가 들어온다. 단어는 알파벳 소문자로만 되어있고 중복되지 않으며, 길이는 최대 100이다.

 

출력

 

첫째 줄에 그룹 단어의 개수를 출력한다.

 


코드 디자인

 

 

  1. BufferedReader로 전체 단어의 갯수를 입력 받는다.

  2. 단어의 갯수 만큼 반복문을 돌며, 해당 반복문마다 문자열을 새로 입력 받는다.

  3. 입력된 단어가 그룹 단어인지 검사한다.

  4. 먼저 해당 단어 내의 알파벳이 존재하였는지 체크하는 배열을 선언한다.
    배열 각 index당 값은                 a = 0, b = 1, c = 2, ..., z = 25 이다.

  5. 해당 단어의 길이만큼 반복문을 반복한다.

  6. 반복문을 반복하며, index 값과 index - 1 값의 문자가 다르다면
    배열[index - 'a'] 을 하여 해당 값을 true로 바꾸어 준다.
  7. 만약 배열[index - 'a']가 true라면 이미 이전에 등장한 알파벳으로 false를 반환한다.

 

코드

 

 

 


결과

 

 


개선점

 

국어 공부 좀 해야할거 같다..ㅎ 처음에 ccazzzzbb에서 c, a, z, b가 그룹 단어라고 이해해서, 그러면 '얘는 결과 값이 4개이겠구나!'라고 생각하고 문제에 접근하니 이해가 더욱 안되어서 코드 자체가 안짜였었다. 문제 접근 자체를 이상하게 했던 것이다.. ㅎㅎ 앞으로 이런 실수 좀 적게 그냥 문제를 문제 자체로 이해하려고 노력해야겠다.

 

 

 

 

 

1316번: 그룹 단어 체커

그룹 단어란 단어에 존재하는 모든 문자에 대해서, 각 문자가 연속해서 나타나는 경우만을 말한다. 예를 들면, ccazzzzbb는 c, a, z, b가 모두 연속해서 나타나고, kin도 k, i, n이 연속해서 나타나기 때

www.acmicpc.net