10807번: 개수 세기
첫째 줄에 정수의 개수 N(1 ≤ N ≤ 100)이 주어진다. 둘째 줄에는 정수가 공백으로 구분되어져있다. 셋째 줄에는 찾으려고 하는 정수 v가 주어진다. 입력으로 주어지는 정수와 v는 -100보다 크거
www.acmicpc.net
#include <stdio.h>
int main() {
int n, num, key, count = 0;
int numlist[100];
scanf("%d", &n);
//반복문을 사용해서 배열에 숫자입력
for (int i = 0; i < n; i++) {
scanf("%d", &numlist[i]);
}
scanf("%d", &key);
for (int i = 0; i < n; i++) {
if (numlist[i] == key) count++;
}
printf("%d", count);
return 0;
}
int count = 0;
scanf_s("%d", count);
#define COUNT count
int num[COUNT];
처음에 코드를 쓸때 낭비되는 메모리가 없도록할려는 의도로 변수를 상수로 선언해주고 그 상수를 배열의 크기를 정하도록 하였다. 하지만 이 코드는 컴파일하는 시점에서 변수의 크기를 결정할 수 없기때문에 오류가 발생한다는 것을 간과하였다.
메모리낭비를 줄이고 싶다면 malloc을 사용해서 배열을 할당할 수 있다.
그래서 문제에 나온대로 최대 갯수가 100이니 크기를 100으로 설정해주었다.
'CodingTest > 백준' 카테고리의 다른 글
[c++] 백준 - 5800번: 성적 통계 (0) | 2023.03.25 |
---|---|
[c++] 백준 - 2204번: 도비의 난독증 테스트 (수정) (0) | 2023.03.23 |
[C언어] 백준 - 4673번: 셀프 넘버 (0) | 2023.02.03 |
[C언어] 백준 - 3052번: 나머지 (0) | 2022.11.29 |
[C언어] 백준 - 10818번: 최소, 최대 (0) | 2022.11.29 |