您好,我想使用动态内存分配来执行插入排序。这是我的代码,此代码给我错误,要求使用左值。请帮助我。

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;

关于c - 使用动态内存分配进行插入排序,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/26091819/

10-10 07:58