我有一个array里面有这些的话,0 2 1 4 3 9 5 7 6 8 1 2 3 8 6 4 。我要删除2变成0 1 4 3 9 5 7 6 8 1 3 8 6 4
void remove(int* heap, int key, int & size) {}怎么才能把我删除的元素后面的都往左移1位
我现在写了这样的
void remove(int* heap, int key, int & size) {
/**
* THIS FUNCTION NEEDS TO BE IMPLEMENTED
*/
for (int i=0;i<size;i++){
if(heap[i]==key){
for (int j=i;j<(size-i);j++){
heap[j]=heap[j+1];
}
size--;
}
}
但不知道为啥 删除2 变这样的
0 1 4 3 9 5 7 6 8 1 2 3 8 6
第二个2 后面怎么没往前移?而且6后面的4怎么没了
arrayä¹å°±æ¯æ°ç»ï¼è¦å é¤æ°ç»ä¸çæä¸ä¸ªå
ç´ ï¼ç±äºæ°ç»çè¿ç»æ§ï¼ä¸å¯è½ç´æ¥å é¤æ对åºçåå¨ç©ºé´ï¼æ以å¯ä¸çæ¹æ³å°±æ¯ç¨æ°ç»åç»å
ç´ è¦çè¦å é¤çå
ç´ ãå³ä»è¦å é¤å
ç´ ä¸ä¸ä¸ªå
ç´ å¼å§ï¼ä¸ç´å°æ°ç»ç»æï¼æ¯ä¸ªå
ç´ ååå移å¨ä¸ä½ã
以ä¸æ¯å é¤ä¸ä¸ªæ°ç»ä¸æ个å
ç´ ç模æ¿å½æ°ï¼