现在功能OK了,主题实现了。谢谢大家。
我在类中有以下非常简单的结构:
struct Data
{
string name1;
string name2;
string name3;
string name4;
}
我初始化:
Data **data;
data=new Data*[size];
问题是将所有指向数组元素的指针从位置 N 移到 right,这样我就可以在 N 中插入一个新元素。我尝试了各种方法,但一切都以指向的元素数组结束同一个对象...
我有类似的功能,它删除元素并将所有内容向左移动。它工作正常:
int Del_element(/*some parameters*/)
{
found=Bin_search(Name1,Name2); //binary search. Returns index of element.
if (found<0) return 0; //element wasn't found
delete data[found]; //delete pointer
for (int i=found; i<index-1; i++) //shift all pointers to the left
{
data[i]=data[i+1];
}
index--;
return 1;
}
我实现的功能如下:
void re_size()
{
int size_old=size;
size*=2;
Data **tmp_array;
tmp_array = new Data*[size];
copy(data, data+size_old, tmp_array);
delete []data;
data=new Data*[size];
data=tmp_array;
}
int Add( const string & Name1,const string & Name2,const string & Name3, const string & Name4 )
{
int found=Bin_search(Name1,Name2); //binary search. Return positive number if found, or negative as the position to insert new element;
if (found>0) //if element already exists
{
return 0;
}
if ((index+1)==size) {re_size();}
data[index]= new Record(Name1,Name2,Name3,Name4);
if (index>0)
{
for (int i=index; i>-found; i--)
{
*data[i]=*data[i-1];
}
data[-found]->name1=Name1;
data[-found]->name2=Name1;
data[-found]->name3=Name1;
data[-found]->name4=Name1;
}
index++;
return 1;
}
基本上,我在数组末尾初始化新元素,然后将元素从数组末尾复制到找到的位置并将值复制到数据 [-found]。