C++에서 배열을 선언하고 초기화를 해주지 않으면 배열은 쓰레기 값으로 채워져있다.
아래의 코드를 실행해보면
#include <iostream>
using namespace std;
int main() {
int arr[5];
for (int i = 0; i < 5; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
이렇게 쓰레기 값으로 채워져있는 것을 볼 수 있다.
따라서 배열을 선언하면 초기화를 꼭 해주는 것이 좋다.
배열 arr의 원소를 모두 0으로 초기화하고 싶다면
int arr[5] = {};
#include <iostream>
using namespace std;
int main() {
int arr[5] = {};
for (int i = 0; i < 5; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
배열 arr의 원소 5개가 모두 0으로 초기화된 것을 볼 수 있다.
만약에 배열의 0번째 원소만 10으로 초기화하고 나머지는 다 0으로 초기화하고 싶다면?
int arr[5] = { 10 };
또는
int arr[5] = { 10, };
여기에서 주의할 점은 위 코드는 모든 원소를 10으로 초기화하는 것이 아니라 첫 번째 원소만 10으로 초기화하는 것이라는 것이다. 이 부분을 잘못 알고 있기 쉬우므로 꼭 기억하자.
#include <iostream>
using namespace std;
int main() {
int arr[5] = { 10 };
for (int i = 0; i < 5; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
첫 번째 원소만 10으로 초기화된 것을 볼 수 있다.
첫 번째 원소를 10으로, 두 번째 원소를 3으로, 나머지는 0으로 초기화하고 싶다면
int arr[5] = { 10, 3 }
#include <iostream>
using namespace std;
int main() {
int arr[5] = { 10, 3 };
for (int i = 0; i < 5; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
첫 번째 원소가 10, 두 번째 원소가 3으로, 나머지는 0으로 초기화 된 것을 볼 수 있다.
그런데 만약 모든 원소를 0이 아닌 특정 값으로 초기화하고 싶다면?
배열의 크기가 5 정도로 작다면
int arr[5] = { 10, 10, 10, 10, 10 }
이렇게 직접 초기화 해줄 수 있지만 배열의 크기가 1000, 10000, 100000 등 큰 수라면 이렇게 직접 초기화 하기에는 무리가 있다.
그럴 때 일반적으로 이렇게 반복문으로 초기화를 시킨다.
#include <iostream>
using namespace std;
int main() {
int arr[5];
for (int i = 0; i < 5; i++) {
arr[i] = 10;
}
for (int i = 0; i < 5; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
이렇게 10으로 초기화된 것을 볼 수 있지만 함수를 이용해서 더 편리하게 초기화할 수 있는 방법이 있다.
바로 <algorithm> 헤더에 있는 fill 함수이다.
fill 함수를 사용하려면 일단 <algorithm> 헤더를 포함해줘야 한다.
사용 방법은
fill(초기화 시키고 싶은 부분의 시작 주소, 초기화시키고 싶은 부분의 끝 주소, 초기화할 값);
배열이라면
fill(arr, arr + 5, 10);
벡터라면
fill(v.begin(), v.end(), 10);
#include <iostream>
#include <algorithm>
using namespace std;
int main() {
int arr[5];
fill(arr, arr + 5, 10);
for (int i = 0; i < 5; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
이렇게 부분 부분씩 초기화시켜줄 수도 있다.
#include <iostream>
#include <algorithm>
using namespace std;
int main() {
int arr[5];
fill(arr, arr + 2, 10);
fill(arr + 2, arr + 5, 20);
for (int i = 0; i < 5; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
벡터도 마찬가지이다.
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
int main() {
vector<int> v(5);
fill(v.begin(), v.end(), 10);
for (int i = 0; i < 5; i++) {
cout << v[i] << " ";
}
cout << endl;
return 0;
}
이 코드를 실행하면
하지만 벡터는 굳이 fill 함수를 안 쓰고
vector<int> v(5, 10);
'CS > 자료구조 & 알고리즘' 카테고리의 다른 글
누적 합 (Prefix Sum) (0) | 2023.09.25 |
---|---|
비트마스크 (BitMask) 알고리즘 (0) | 2023.09.23 |
각 정렬의 특징 및 장단점 & 시간복잡도 + 코드 (0) | 2023.09.07 |
유클리드 호제법 - 최대공약수(GCD) 구하기 (0) | 2023.09.04 |
에라토스테네스의 체 (0) | 2023.09.03 |