功能現在可以,主題已實現。感謝大家。C++指向結構的指針陣列
我有以下的類裏面結構非常簡單:
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;
}
基本上,我在數組的末尾初始化新的元素,然後從數組的末尾,以發現位置複製的元件和將值複製到數據中[-found]。
這功課嗎?此外,你已經給了我們*可用的代碼*,但不是沒有的代碼? – mfontanini
我更新了我的答案。覈實。 – JalalJaberi
爲什麼你不使用'std :: vector'? – mfontanini