[Python] 백준 BaekJoon 1157

2021. 8. 15. 11:51Algorithm/BaekJoon

 

1157번: 단어 공부

알파벳 대소문자로 된 단어가 주어지면, 이 단어에서 가장 많이 사용된 알파벳이 무엇인지 알아내는 프로그램을 작성하시오. 단, 대문자와 소문자를 구분하지 않는다.

www.acmicpc.net

문제

알파벳 대소문자로 된 단어가 주어지면, 이 단어에서 가장 많이 사용된 알파벳이 무엇인지

알아내는 프로그램을 작성하시오. 단, 대문자와 소문자를 구분하지 않는다.

 

입력

첫째 줄에 알파벳 대소문자로 이루어진 단어가 주어진다.

주어지는 단어의 길이는 1,000,000을 넘지 않는다.

 

출력

첫째 줄에 이 단어에서 가장 많이 사용된 알파벳을 대문자로 출력한다.

단, 가장 많이 사용된 알파벳이 여러 개 존재하는 경우에는 ?를 출력한다.

 

 

[풀이법]

1. 대소문자를 별도로 구분하지 않기 위해 입력받을 때 모든 입력값을 대문자로 입력

   (대문자가 아닌, 소문자로 변환해도 관계 없다)

   * upper( ) : 대문자, lower( ) : 소문자 

 

2. 입력받은 문자열에서 중복값을 없애기 위해 set( )을 이용,

    list 형태로 새로운 변수(Alphabet)에 담아준다

 

3. 중복값을 제거한 Alphabet의 수를 세어 담아줄 빈 리스트 Alphabet_count 생성

 

4. Alphabet의 길이만큼 반복하며 순회

   입력받은 문자열 S안에 Alphabet의 각 단어가 몇 개 들었는지 세어서 count 변수에 저장

   * count( ) 를 사용해서 쉽게 해당 문자의 개수를 파악할 수 있다

   

   append를 이용해서 빈 리스트(Alphabet_count)에 count 숫자 값을 순서대로 반복하여 저장

 

5. Alphabet_count 안에서 반복횟수가 가장 큰 수를 찾았을 때 그 수가 1개 이상이라면 ?를 출력

 

6. 아니라면, 가장 큰 수가 Alphabet_count의 몇 번째 인덱스에 위치하는지 위치 값을 저장한다

 

7. 저장된 위치값으로 중복값을 제거했던 Alphabet의 인덱스를 직접 참조

   참조된 인덱스 안에 할당되있는 값이 해당 문자열에서 가장 많이 사용된 알파벳이 된다

'Algorithm > BaekJoon' 카테고리의 다른 글

[Python] 백준 BaekJoon 2908  (0) 2021.08.16
[Python] 백준 BaekJooon 1152  (0) 2021.08.16
[Python] 백준 BaekJoon 2675  (0) 2021.08.15
[Python] 백준 BaekJoon 10809  (0) 2021.08.15
[Python] 백준 BaekJoon 11720  (0) 2021.08.14