티스토리 뷰

Programming/C++

[C++] vector 기본 사용방법

감성적인 개발자 2021. 7. 26. 23:22

#include<vector>

동적 배열을 더 편리하게 사용할 수 있게 해주는 대체제이다. 가장 큰 차이점은

  1. 크기를 별도로 선언할 필요가 없으며 크기 변경이 용이하다.

  2. 스코프를 벗어나면 자동으로 메모리를 해제해준다. (delete[] array 를 자동으로 수행)

 

vector에서 자주 사용되는 멤버 함수

  v.push_back() vector의 맨 끝에 원소 추가
  v.pop_back() vector의 맨 끝 원소 제거
  v.at(0) n 번째 원소를 참조, 범위 체크를 하므로 v[0]보다 느림
  v.front() 첫 번째 원소를 참조해 리턴
  v.back() 마지막 원소를 참조해 리턴
  v.size() vector에 있는 원소 개수를 리턴
  v.capacity() vector에 할당된 메모리 크기 리턴
  v.clear() vector의 모든 요소를 제거한다.

 

 

선언

#include<vector>

vector<int> v;
vector<int> v2(10);	// 크기를 미리 할당

예시

using namespace std;
int main(){
	vector<int> v2(5);
	v2.resize(10);
	v2 = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11};
	cout << v2.size() << '\n';  // 11
	v2.resize(5);
	for(auto &itr : v2){
	    cout << itr << ' ';
	}
	cout << v2.size() << '\n';
}

출력

11
1 2 3 4 5 6 7 8 9 10 11
1 2 3 4 5
5

resize를 통해 벡터의 길이를 10으로 변경한 뒤, 11개 요소를 집어넣었다. 그럼에도 오버플로우 없이 길이또한 자동으로 변경됐다. (가독성을 위해 줄바꿈) 

또한 resize를 통해 벡터의 길이를 줄이면 뒤에서부터 요소가 제거되는 것을 알 수 있다.

 

 

string vector 사용 예시

using namespace std;

int main(){
    vector<string> sv;
    string s = "sample test";
    sv.push_back(s);
    cout << "sv[0] : " << sv[0] << '\n';
    cout << "sv[0].length() : " << sv[0].length() << '\n';
    cout << "sv.size() : " << sv.size() << '\n';
}

출력

sv[0] : sample test
sv[0].length() : 11
sv.size() : 1

 

 

 

예제

 

코딩테스트 연습 - 행렬의 덧셈

행렬의 덧셈은 행과 열의 크기가 같은 두 행렬의 같은 행, 같은 열의 값을 서로 더한 결과가 됩니다. 2개의 행렬 arr1과 arr2를 입력받아, 행렬 덧셈의 결과를 반환하는 함수, solution을 완성해주세요

programmers.co.kr

 

댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/12   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31
글 보관함