mirror of
https://github.com/krahets/hello-algo.git
synced 2025-11-02 04:31:55 +08:00
Fix the index out of bound check in my_list.
This commit is contained in:
@ -38,14 +38,14 @@ public:
|
||||
/* 访问元素 */
|
||||
int get(int index) {
|
||||
// 索引如果越界则抛出异常,下同
|
||||
if (index >= size())
|
||||
if (index < 0 || index >= size())
|
||||
throw out_of_range("索引越界");
|
||||
return nums[index];
|
||||
}
|
||||
|
||||
/* 更新元素 */
|
||||
void set(int index, int num) {
|
||||
if (index >= size())
|
||||
if (index < 0 || index >= size())
|
||||
throw out_of_range("索引越界");
|
||||
nums[index] = num;
|
||||
}
|
||||
@ -62,7 +62,7 @@ public:
|
||||
|
||||
/* 中间插入元素 */
|
||||
void insert(int index, int num) {
|
||||
if (index >= size())
|
||||
if (index < 0 || index >= size())
|
||||
throw out_of_range("索引越界");
|
||||
// 元素数量超出容量时,触发扩容机制
|
||||
if (size() == capacity())
|
||||
@ -78,7 +78,7 @@ public:
|
||||
|
||||
/* 删除元素 */
|
||||
int remove(int index) {
|
||||
if (index >= size())
|
||||
if (index < 0 || index >= size())
|
||||
throw out_of_range("索引越界");
|
||||
int num = nums[index];
|
||||
// 索引 i 之后的元素都向前移动一位
|
||||
|
||||
Reference in New Issue
Block a user