Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 29 | 30 |
Tags
- 도선생님 신경론
- 앤드류 테이트
- 롤에 돈얼마나썼지
- Class1
- 자바메모
- 쿠르츠 게작트
- 명언
- 도파 신경론
- 티스토리 코드블록
- 스팀에 돈 얼마나 썼지
- 비주얼스튜디오 코드 폰트
- 어도비플래시서비스종료
- 스팀 사용 금액
- 신경론
- 백준
- 게임 네트워킹
- 티스토리전체글수
- 롤 현질얼마나 했는지보기
- 티스토리사진
- 티스토리사진한줄에 여러개
- 가운뎃점 입력
- c++
- 어도비플래시삭제
- 언리얼
- 자바스크립트 defer
- 롤 현질금액보기
- 티스토리 전체글수표시
- 비주얼스튜디오 코드 글꼴
- 한글 가운뎃점
- 스팀 돈얼마나 썼는지보기
Archives
- Today
- Total
Small Step
[C++] 백준 1157번 - 단어 공부 본문
https://www.acmicpc.net/problem/1157
문제 설명
주어진 단어에서 가장 많이 사용된 알바펫을 찾는 문제.
가장 많이 사용된 알파벳이 여러개라면 ? 를 출력
#include <iostream>
#include <string>
#include <stdio.h>
using namespace std;
int main() {
string str;
cin >> str;
int len = str.length();
int chk[26] = { 0, };
for (int i = 0; i < len; i++) {
if (str[i] > 96) chk[str[i] - 97]++;
else chk[str[i] - 65]++;
}
int max = 0;
int cnt = 0;
char name = '0';
for (int j = 0; j < 26; j++) {
if (chk[j] > max) max = chk[j];
}
for (int j = 0; j < 26; j++) {
if (chk[j] == max) {
name = j;
cnt++;
}
}
if (cnt == 1) {
printf("%c", name + 65);
}
else {
cout << '?';
}
}
빈도수 찾기
알파벳 개수만큼 26칸의 배열을 만들고 문자열의 길이를 알아내 for문을 돌렸다.
이 문제에서는 소문자와 대문자는 같게 빈도수를 측정한다.
아스키코드를 활용해서 풀었다.
가장 많이 사용된 알파벳 찾기
아스키코드에 따르면 65~90 까지는 대문자, 97~122 까지는 소문자인 점을 활용해 조건문을 만들었다.
그렇게 알파벳 배열에 빈도수가 저장되고
최댓값과 사용된 알파벳 개수를 세주는 코드를 넣었다.
최댓값을 정하고 다시 배열과 비교해서 가장 많이 사용된 알파벳이 한 개 인지 여러 개인지 파악했다.
한 개라면 대문자로 배열의 알파벳을 출력해주고
여러개라면 ?를 출력해준다.
'알고리즘 > 백준' 카테고리의 다른 글
[C++] 백준 10809번 - 알파벳 찾기 (0) | 2022.07.25 |
---|---|
[C++] 백준 11654번 - 아스키 코드 (0) | 2022.07.25 |
[C++] 백준 1152번 - 단어의 개수 (0) | 2022.07.25 |
[C++] 백준 2675번 - 문자열 반복 (0) | 2022.07.24 |
[C++] 백준 10870번 - 피보나치 수 5 (0) | 2022.07.24 |
Comments