728x90
728x90

문제

총 N개의 정수가 주어졌을 때, 정수 v가 몇 개인지 구하는 프로그램을 작성하시오.

 

입력

첫째 줄에 정수의 개수 N(1 ≤ N ≤ 100)이 주어진다. 둘째 줄에는 정수가 공백으로 구분되어져있다. 셋째 줄에는 찾으려고 하는 정수 v가 주어진다. 입력으로 주어지는 정수와 v는 -100보다 크거나 같으며, 100보다 작거나 같다.

 

출력

첫째 줄에 입력으로 주어진 N개의 정수 중에 v가 몇 개인지 출력한다.

 

예제 입력 1

11
1 4 1 2 4 2 4 2 3 4 4
2

 

예제 출력 1

3

 

예제 입력 2

11
1 4 1 2 4 2 4 2 3 4 4
5

 

예제 출력 2

0
 

알고리즘 분류

  • 구현

 

문제 출처

https://www.acmicpc.net/problem/10807

 

10807번: 개수 세기

첫째 줄에 정수의 개수 N(1 ≤ N ≤ 100)이 주어진다. 둘째 줄에는 정수가 공백으로 구분되어져있다. 셋째 줄에는 찾으려고 하는 정수 v가 주어진다. 입력으로 주어지는 정수와 v는 -100보다 크거

www.acmicpc.net

 


 

문제 해결 방법

  • 1차원 배열과 for 문을 이용하여 가볍게 풀었던 문제였다.
  • [단계별로 풀어보기] 문제집에 새로운 문제가 추가되어 문제를 풀어보았다.

 

코드

#include <iostream>
using namespace std;

int N, V;
int ary[101];

void Input() {
    cin >> N;
    for (int i = 1; i <= N; i++) {
        cin >> ary[i];
    }
    cin >> V;
}

int Solution(int n, int v) {
    int count = 0;
    for (int i = 1; i <= n; i++) {
        if (ary[i] == v) {
            count++;
        }
    }
    
    return count;
}

void Output() {
    cout << Solution(N, V) << '\n';
}

void Solve() {
    Input();
    Output();
}

int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL);

    Solve();

    return 0;
}

 

채점 결과

 

참고

  • [단계별로 풀어보기] > [1차원 배열]
  • 브론즈V
728x90
728x90