ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [ 5597 ] 과제 안 내신 분 ..? - array, vector
    알고리즘/BOJ 2021. 7. 27. 14:37

    < array, vector > - < solve등급 >

     

    [ 5597 ]

    과제 안 내신 분 ..?

    X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.

    교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.

     

    :: 입력

    입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.

    :: 출력

    출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.


     

    - try 1 

    : 31짜리 배열을 만들고 입력으로 들어온 번호를 표기

    입력을 모두 받으면 배열을 처음부터 끝까지 확인해서 비어있는 부분의 index를 벡터에 저장해준다

    처음에는 그냥 int min max 에 담으려고 했는데 어차피 배열을 앞에서부터 검사할거라서 할 필요가 없었음

    그렇다고 사이즈 2짜리 배열을 쓰면 

    따로 그 배열을 위한 인덱스를 만들어야해서 벡터사용함

     

      정답  코드  

    #include <string>
    #include <vector>
    #include <iostream>
    #include <algorithm>
    #include <cstdio>
    
    using namespace std;
    
    #define endl "\n"
    
    int main() {
    	int nums[31] = { 0, };
    	vector<int> res;
    	int num;
    
    	for (int i = 0; i < 28; i++) {
    		scanf("%d", &num);
    		nums[num] = 1;
    	}
    
    	for (int i = 1; i < 31; i++) {
    		if (nums[i] == 0) {
    			res.push_back(i);
    		}
    	}
    
    	for (int i = 0; i < res.size(); i++) {
    		printf("%d\n", res[i]);
    	}
    }

     

      정답  코드  

    #include<stdio.h>
    int main(){
    	int a[30]={0}, n, i;
    	for(i=0;i<28;i++){
    		scanf("%d",&n);
    		n=n-1;
    		a[n]++;
    	}
    	for(i=0;i<30;i++){
    		if(a[i]==0) printf("%d\n",i+1);
    	}
    	return 0;
    }

     

    '알고리즘 > BOJ' 카테고리의 다른 글

    [ 2751 ] 수 정렬하기 2  (0) 2021.08.12
    [ 6996 ] 애너그램 - array, vector  (0) 2021.07.27
    [ 2953 ] 나는 요리사다 - array, vector  (0) 2021.07.27
    [ 2920 ] 음계 - array, vector  (0) 2021.07.27
    [ 11328 ] Strfry - array, vector  (0) 2021.07.26
준생e