思路
设计一个 Insert(int data,int n) 函数,使得一个存有该数据的节点能够插入第n个位置。
代码实现
设计一个 Insert 函数,一个 Print 函数 以及 main 函数。
#include<stdio.h>
#include<stdlib.h>
struct Node{
int data;
struct Node* next;
};
struct Node* head;//定义一个全局变量head,使所有的函数都能够调用,无需传参。
void Insert (int data,int n){
struct Node* temp1 = (struct Node*)malloc(sizeof(struct Node));
temp1->data = data;
temp1->next = NULL;
if(n==1){
temp1->next = head;
head = temp1;
return;
}
struct Node* temp2 = head;
for(int i=0;i<n-2;i++){
temp2 = temp2->next;//循环后的temp2是第n-1个Node的地址,也是第n-2个Node的next值
}
temp1->next = temp2->next;
temp2->next = temp1;//第n-1个Node的next更改为插入Node的地址
}
void Print(){
struct Node* temp = head;
while(temp != NULL){
printf("%d ",temp->data);
temp = temp->next;
}
printf("\n");
}
int main(){
head = NULL;
printf("How many numbers?\n");
int n,i,number,position;
scanf("%d",&n);
for(i=0;i<n;i++){
printf("Enter the number and position\n");
scanf("%d%d",&number,&position);
Insert(number,position);
Print();
}
return 0;
}