c-使用动态内存分配的插入排序



你好,我想使用动态内存分配执行插入排序。这是我的代码,这个代码给了我一个错误,即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;

相关内容

  • 没有找到相关文章

最新更新