我想在C中添加一個函數來將數字添加到一個有序的鏈表中,但是我已經得到了 感覺它可以在很少的行中完成。有沒有例子?如何在排序的鏈接列表中添加數字?
此示例代碼不起作用:
#include <stdio.h>
#include <stdlib.h>
struct listNode {
int number;
struct listNode *nextPtr;
};
typedef struct listNode LISTNODE;
typedef LISTNODE *LISTNODEPTR;
int main()
{
LISTNODE a = {16,NULL};
LISTNODEPTR ptr = &a;
printList(&a);
insert(&ptr,23);
insert(&ptr,10);
insert(&ptr,12);
insert(&ptr,15);
printList(&a);
return 0;
}
void insert(LISTNODEPTR *list, int number){
if((**list).number > number){
printf("lol2 %d",number);
LISTNODE *newNode = malloc(sizeof(LISTNODE));
(*newNode).number = number;
(*newNode).nextPtr = (*list);
*list = newNode;
}else if((**list).nextPtr == NULL){
printf("lol %d",number);
LISTNODE *newNode = malloc(sizeof(LISTNODE));
(*newNode).number = number;
(*newNode).nextPtr = NULL;
(**list).nextPtr = newNode;
}else{
printf("other %d\n",number);
LISTNODE *listPtr = *list;
LISTNODE *listPtr1 = (*listPtr).nextPtr;
while((*listPtr1).number < number && (*listPtr).nextPtr != NULL){
printf("%d > %d\n",(*listPtr).number , number);
listPtr = (*listPtr).nextPtr;
listPtr1 = (*listPtr).nextPtr;
}
LISTNODE *newNode = malloc(sizeof(LISTNODE));
(*newNode).number = number;
if((*listPtr).nextPtr != NULL){
(*newNode).nextPtr = listPtr1;
}else{
(*newNode).nextPtr = NULL;
}
(*listPtr).nextPtr = newNode;
}
}