これで機能はOK、話題は達成。みんな、ありがとう。
クラス内に次の非常に単純な構造があります。
struct Data
{
string name1;
string name2;
string name3;
string name4;
}
私は初期化します:
Data **data;
data=new Data*[size];
問題は、配列の要素へのすべてのポインターを位置 N から右にシフトして、新しい要素を 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;
}
基本的に、配列の末尾で新しい要素を初期化し、配列の末尾から見つかった位置に要素をコピーし、値を data[-found] にコピーします。