0_ch4n
기계쟁이\n개발자
0_ch4n
0chn.xxx@gmail.com @0ch._.n
전체 방문자
오늘
어제

공지사항

  • All (282)
    • 🖥 CS (21)
      • 네트워크 (12)
      • 운영체제 (3)
      • 자료구조 (2)
      • Web (4)
    • 🧠 Algorithm (185)
      • [C] BOJ (93)
      • [JAVA] Programmers (91)
    • 📚 Study (69)
      • HTML&CSS (19)
      • MySQL (11)
      • JAVA (22)
      • Servlet&JSP (8)
      • Thymeleaf (2)
      • Spring (5)
      • JPA (2)
    • 📖 Book (1)
    • 📃 Certification (6)
      • 정보처리기사 (6)

인기 글

최근 글

최근 댓글

태그

  • Programmers
  • 코딩테스트
  • 자바
  • 프로그래머스
  • java
  • CSS
  • 카카오
  • kakao
  • til
  • 코테

블로그 메뉴

  • 홈
  • 태그
  • 방명록

티스토리

hELLO · Designed By 정상우.
0_ch4n

기계쟁이\n개발자

[C언어] 1152번 - 단어의 개수
🧠 Algorithm/[C] BOJ

[C언어] 1152번 - 단어의 개수

2022. 3. 31. 11:55
반응형

문제

영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열에는 몇 개의 단어가 있을까? 이를 구하는 프로그램을 작성하시오. 단, 한 단어가 여러 번 등장하면 등장한 횟수만큼 모두 세어야 한다.

입력

첫 줄에 영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 공백 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 문자열은 공백으로 시작하거나 끝날 수 있다.

출력

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

코드

#include <stdio.h>
#include <string.h>
#define len 1000000

int main(void) {
	
	char str[len] = {};
	int cnt = 0;
	int i = 0;
	
	scanf("%[^\n]", str); //줄바꿈까지 문자열 입력 

	if(str[0] == ' ') { //첫 글자가 공백이라면 두번째 글자부터 본다
		i = 1;
	}

	while(str[i] != '\0') { //배열에 각 인덱스의 문자가 null일 때까지 반복
		if(str[i] == ' ') { //공백을 찾았다면 개수를 세준다
			cnt++;
		}
		
		i++;
	}

	if(str[i - 1] == ' ') { //마지막 글자가 공백이라면 
		printf("%d", cnt);
	}
	else { //마지막 글자에 공백이 없다면
		printf("%d", cnt + 1);
	}
	
	return 0;
}
반응형
저작자표시 (새창열림)

'🧠 Algorithm > [C] BOJ' 카테고리의 다른 글

[C언어] 5622번 - 다이얼  (0) 2022.03.31
[C언어] 2908번 - 상수  (0) 2022.03.31
[C언어] 1157번 - 단어 공부  (0) 2022.03.31
[C언어] 2675번 - 문자열 반복  (0) 2022.03.31
[C언어] 10809번 - 알파벳 찾기  (0) 2022.03.31
    0_ch4n
    0_ch4n
    while(true) { study(); }

    티스토리툴바