Notice
Tags
- Image_classification
- pytorch
- Linux
- study
- SingleProject
- cloud_computing
- Database_Design
- Algorithm
- 오블완
- 티스토리챌린지
- app
- programmers
- Unix_System
- C
- tensorflow
- Baekjoon
- Univ._Study
- c++
- Java
- datastructure
- Android
- Kubernetes
- Personal_Study
- Artificial_Intelligence
- Python
- Operating_System
- codingTest
- 자격증
- 2023_1st_Semester
- 리눅스마스터2급
코딩 기록 저장소
[백준/Java] 1152번: 단어의 개수 본문
문제 정보
제목 : 단어의 개수
번호 : 1152번
사용 언어 : Java
문제 링크
https://www.acmicpc.net/problem/1152
1152번: 단어의 개수
첫 줄에 영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 공백 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 문자열
www.acmicpc.net
시간 제한 | 메모리 제한 |
2초 | 128MB |
문제
영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열에는 몇 개의 단어가 있을까? 이를 구하는 프로그램을 작성하시오. 단, 한 단어가 여러 번 등장하면 등장한 횟수만큼 모두 세어야 한다.
입력
첫 줄에 영어 대소문자와 공백으로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 공백 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 문자열은 공백으로 시작하거나 끝날 수 있다.
출력
첫째 줄에 단어의 개수를 출력한다.
입출력 예제

나의 풀이
문자열형 배열에 입력받은 문자를 split()함수를 이용해 공백을 기준으로 저장합니다. 문자열형 배열의 길이만큼 반복하는 for문을 이용하여 배열의 값이 ""(공백)이 아니라면 count의 값을 +1해줍니다. 이를 하는 이유는 해당 문자열이 공백으로 시작하거나 끝날 수 있기 때문입니다. 반복이 끝나면 count를 출력합니다.
코드
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String[] str_array = sc.nextLine().split(" ");
int count = 0;
for(int i = 0; i < str_array.length;i++) {
if( str_array[i].equals("")) {
} else {
count++;
}
}
System.out.println(count);
sc.close();
}
}
'백준 > 문자열 (완료)' 카테고리의 다른 글
[백준/Python] 11720번 : 숫자의 합 (0) | 2024.01.18 |
---|---|
[백준/Python] 11654번 : 아스키 코드 (0) | 2024.01.18 |
[백준/Java] 9086번: 문자열 (0) | 2023.05.22 |
[백준/Java] 2743번: 단어 길이 재기 (0) | 2023.05.22 |
[백준/Java] 27866번: 문자와 문자열 (0) | 2023.05.16 |