일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 스팀 돈얼마나 썼는지보기
- 신경론
- 롤에 돈얼마나썼지
- 도선생님 신경론
- 쿠르츠 게작트
- 가운뎃점 입력
- 비주얼스튜디오 코드 글꼴
- 명언
- 백준
- 앤드류 테이트
- 스팀 사용 금액
- 롤 현질금액보기
- Class1
- 자바메모
- 자바스크립트 defer
- 비주얼스튜디오 코드 폰트
- c++
- 티스토리사진한줄에 여러개
- 게임 네트워킹
- 롤 현질얼마나 했는지보기
- 티스토리사진
- 스팀에 돈 얼마나 썼지
- 어도비플래시서비스종료
- 티스토리 코드블록
- 한글 가운뎃점
- 어도비플래시삭제
- 티스토리전체글수
- 도파 신경론
- 언리얼
- 티스토리 전체글수표시
- Today
- Total
Small Step
[C++] 백준 10809번 - 알파벳 찾기 본문
https://www.acmicpc.net/problem/10809
10809번: 알파벳 찾기
각각의 알파벳에 대해서, a가 처음 등장하는 위치, b가 처음 등장하는 위치, ... z가 처음 등장하는 위치를 공백으로 구분해서 출력한다. 만약, 어떤 알파벳이 단어에 포함되어 있지 않다면 -1을 출
www.acmicpc.net
주어진 단어에서 특정 알파벳이 몇 번째 위치에 나오는지 출력하는 문제이다.
만약 같은 알파벳이 여러 번 나오면 첫 번째 위치만을 출력한다.
알파벳이 사용되지 않았으면 -1 출력한다.
#include <iostream>
#include <string>
using namespace std;
int main() {
string str;
cin >> str;
int chk[26];
fill_n(chk, 26, -1);
int len = str.length();
for (int i = 0; i < len; i++) {
if (chk[str[i] - 97] == -1) {
chk[str[i] - 97] = i;
}
}
for (int j = 0; j < 26; j++) {
cout << chk[j] << ' ';
}
}
배열 초기화
일단 알파벳 수만큼 배열을 만들고 알파벳이 나오지 않는 것을 기본으로 하여 -1로 초기화를 해줘야 한다.
for문을 사용할 수도 있지만 fill_n이라는 함수를 사용해봤다.
https://bb-dochi.tistory.com/6
[c/c++] 배열 한번에 초기화하는 법
일단 0으로 초기화하는 방법은 int array[10] = {0,}; 그럼 다른 값으로 초기화 하려면 int array[10] = {5,}; 가 될까 싶었는데, 결론적으론 안된다. (첫 원소값만 5가 되고 나머지는 0으로 초기화 된다) 그럼
bb-dochi.tistory.com
배열은 다른 방법으로도 초기화해줄 수 있다.
등장 위치 찾기
문제 풀이는 1157번 문제하고 매우 비슷하다.
알파벳이 소문자만 나온다는 점을 이용하여 아스키코드를 이용해 풀었다.
주어진 문자열의 길이를 알아내 하나씩 비교해간다.
같은 알파벳이 여러 번 나올 수도 있으니 알파벳 배열의 값이 -1일 때만 위치를 저장해준다.
출력
알파벳 배열을 공백으로 구분해 출력 형식에 맞게 출력해준다.
'알고리즘 > 백준' 카테고리의 다른 글
[C++] 백준 10871번 - X보다 작은 수 (0) | 2022.07.25 |
---|---|
[C++] 백준 2475번 - 검증수 (0) | 2022.07.25 |
[C++] 백준 11654번 - 아스키 코드 (0) | 2022.07.25 |
[C++] 백준 1157번 - 단어 공부 (0) | 2022.07.25 |
[C++] 백준 1152번 - 단어의 개수 (0) | 2022.07.25 |