C의 벡터 크기 이해
C에서 벡터 데이터 구조는 요소가 추가됨에 따라 자동으로 크기를 조정할 수 있는 동적 배열입니다. 또는 제거되었습니다. 그러나 벡터로 작업할 때는 벡터가 비어 있을 때 size()의 동작을 이해하는 것이 중요합니다.
빈 벡터에 대해 size() - 1이 -1이 아닌 이유
제공된 코드 조각을 고려하세요.
#include <vector> #include <iostream> using namespace std; int main() { vector<int> value; cout << value.size() << endl; // output 0 cout << value.size() - 1 << endl; // output 18446744073709551615 }
첫 번째 출력인 0은 빈 벡터의 요소입니다. 그러나 크기에서 1을 뺀 두 번째 출력은 -1 대신 부호 없는 큰 정수를 반환하므로 예상치 못한 결과를 낳습니다.
이 동작의 이유는 vector::size에 사용되는 size_t 유형에 있습니다. (). size_t는 벡터의 요소 수를 저장하도록 설계된 부호 없는 정수 유형입니다. 부호 없는 정수는 음수를 나타낼 수 없으므로 0에서 1을 빼려고 하면 큰 부호 없는 정수 값이 생성됩니다.
결론
size_t가 다음과 같다는 점을 기억하는 것이 중요합니다. 부호 없는 유형이며 음수를 나타낼 수 없습니다. 벡터로 작업할 때 빈 벡터의 크기에서 1을 뺄 때 부호 없는 정수 값이 커질 가능성을 항상 고려하세요.
위 내용은 왜 C의 빈 벡터에 대해 `Vector.size() - 1`이 -1을 반환하지 않습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!