我是C ++的新手,我想知道如何从阵列中动态插入和删除项目。例如:
>> insert(1)
[1]
>> insert(2)
[1,2]
>> delete()
[1]
目前我对任何库都不感兴趣,我只想掌握C ++的基础知识。我还应该提一下,数组将没有值开始。
答案 0 :(得分:3)
由于您对STL容器不感兴趣(虽然我建议您查看例如vector
),但声明一个您想要的最大大小的数组
int arr[10];
现在通过索引访问数组中的元素并分配值
arr[0] = 5; //indexes start from 0 and in this case till 9
或者将索引的变量保留为
int index = 0;
插入时,请使用:
arr[index] = value;
index++;
在使数组中的元素可用时,只需将索引递减以指示后面的索引可以自由填充。
编辑:
请参阅以下代码:
#include<iostream>
using namespace std;
int main()
{
int arr[10];
int choice;
int num;
int index = 0;
do
{
cout<<"enter you choice:\n";
cout<<"1. add number\n";
cout<<"2. delete number\n";
cout<<"3. display memory\n";
cout<<"anything else to exit\n";
cin>>choice;
switch(choice)
{
case 1:
if(index==10)
{
cout<<"no more space available\n";
}
else
{
cout<<"enter number: ";
cin>>num;
arr[index++] = num;
}
break;
case 2:
if(index==0)
{
cout<<"memory empty\n";
}
else
{
cout<<"item deleted!\n ";
index--;
}
break;
case 3:
for(int i = 0;i<index;i++)
{
cout<<arr[i]<<'\t';
}
cout<<endl;
break;
default:
cout<<"exiting.......";
}
}while(choice>0 && choice<4);
}
答案 1 :(得分:2)
使用std::vector
。
您可以使用push_back
插入向量的背面,pop_back
删除最后一个元素。
一个例子:
#include <vector>
#include <iostream>
int main()
{
std::vector<int> numbers;
numbers.push_back(1)
numbers.push_back(2);
numbers.pop_back();
for (int i : numbers) { // c++11 range-based for loop
std::cout << i << '\n';
}
}
在您的示例中打印1。
答案 2 :(得分:0)
查看std::vector
std::vector<int> arr;
arr.push_back(1);
arr.push_back(2);
arr.pop_back();
答案 3 :(得分:0)
在C ++的基础知识中,你必须使用一个库(或者自己编写自己的库)。您在每个C ++实现中获得的标准库都有一个名为std::vector
的类,可以执行您想要的操作。
#include <vector>
int main()
{
std::vector<int> a;
a.push_back(1);
a.push_back(2);
a.pop_back();
}