你好,我想使用动态内存分配执行插入排序。这是我的代码,这个代码给了我一个错误,即lvalue是必需的。请帮帮我。
int *cardSorter(int *arrayPointer,int size){
int j,i,key;
for(j=1;j<size;j++){
key=*(arrayPointer+j);
i=j-1;
while(i>=0||*(arrayPointer+i)>key){
*((arrayPointer+i)+1)=*(arrayPointer+i);
i--;
}
//GIVING ERROR AT THIS LINE : lvalue requied
*(arrayPointer+i)+1=key;
}
return arrayPointer;
}
这里ArrayPointer指向的是我动态分配的内存。
正如您的评论中所述,
//GIVING ERROR AT THIS LINE : lvalue requied
*(arrayPointer+i)+1=key;
应该是
*(arrayPointer+i+1) = key;
或者更容易阅读的
arrayPointer[i+1] = key;