일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- php 프로그래밍 입문 솔루션
- programmers
- php 프로그래밍 입문
- php 프로그래밍
- 페이코 추천인
- 스프링
- php 프로그래밍 입문 3판
- php
- Java
- SWEA
- 배열
- C언어
- php 프로그래밍 입문 문제풀이
- 페이코 친구코드
- JAVA SPRING
- 최단 경로
- php 프로그래밍 입문 예제
- 한정 분기
- spring
- C
- 파이썬
- 자바 스프링
- 백준
- php 프로그래밍 입문 연습문제
- 페이코 추천인코드
- 플러터 개발환경 설정
- 페이코 초대코드
- Flutter
- 자바
- 플러터
Archives
- Today
- Total
12-01 10:12
ImJay
[C언어] 백준 1152번 : 단어의 개수 본문
반응형
백준 1152번 : 단어의 개수
- 사용언어 : C언어
1. 문제
영어 대소문자와 띄어쓰기만으로 이루어진 문자열이 주어진다. 이 문자열에는 몇 개의 단어가 있을까? 이를 구하는 프로그램을 작성하시오. 단, 한 단어가 여러 번 등장하면 등장한 횟수만큼 모두 세어야 한다.
2. 코드
#include <stdio.h>
#include <string.h>
#define num 1000001
int main(void) {
char voca[num];
char* tmp;
gets(voca);
int count=0;
tmp = strtok(voca, " ");
while(tmp != NULL) {
count++;
tmp = strtok(NULL, " ");
}
printf("%d", count);
}
3. 풀이
새로 사용하는 함수들이 많습니다. 차근차근 설명하겠습니다.
먼저 char* tmp 입니다.
말그대로 문자열 선언 방식입니다.
char tmp 에서는 문자를 하나밖에 넣지 못하지만,
char* tmp 는 문자를 여러개 넣을 수 있습니다.
gets() 함수는 scanf의 문자열 방식입니다.
문제에서 띄어쓰기로 단어를 구분하므로, strtok 함수를 사용합니다.
strtok 함수는 문자열에서 원하는 문자가 나올 때 문자열에 NULL 값을 저장해 구분해주는 함수입니다.
예제를 예시로 들어보면,
input : The Curious Case of Benjamin Button
tmp = strtok(voca, " "); // tmp = The , voca = \0(NULL)Curious Case of Benjamin Button
tmp = strtok(NULL, " "); // tmp = Curious , voca = \0(NULL)Case of Benjamin Button
strtok를 사용하려면, 처음에는 구분을 원하는 문자열을 넣고, 그 다음 순서에서는 NULL을 넣습니다.
맨 앞에 NULL이 입력되있기 때문이고, strtok를 사용할 때의 약속이기도 합니다.
반응형
'백준 - C, C++ > 07. 문자열' 카테고리의 다른 글
[C언어] 백준 5622번 : 다이얼 (0) | 2020.10.26 |
---|---|
[C언어] 백준 2908번 : 상수 (0) | 2020.10.21 |
[C언어] 백준 1157번 : 단어 공부 (0) | 2020.10.20 |
[C언어] 백준 2675번 : 문자열 반복 (10) | 2020.10.17 |
[C언어] 백준 10809번 : 알파벳 찾기 (0) | 2020.10.15 |
Comments