解题思路:
注意事项:
参考代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct _fushu{
int value;
struct _fushu *next;
}fushu;
void add(fushu **phead);
void print(fushu **phead);
void del_one(fushu **phead,int x,int *count);
void get_one(fushu **phead,int x);
void insert_one(fushu **phead,int x,int y,int *count);
int main()
{
fushu *head = NULL;//核心表头
int n;
scanf("%d",&n);
int count = n;
while(n--)
add(&head);//术式反转
int b;
scanf("%d",&b);
char cmd[7];
while(b--)
{
scanf("%s",cmd);
if(!strcmp(cmd,"show"))
{
print(&head);
}
if(!strcmp(cmd,"delete"))
{
int where;
scanf("%d",&where);
if(where>count || where<1)
printf("delete fail\n");
else
del_one(&head,where,&count);
}
if(!strcmp(cmd,"get"))
{
int where;
scanf("%d",&where);
if(where>count || where<1)
printf("get fail\n");
else
get_one(&head,where);
}
if(!strcmp(cmd,"insert"))
{
int where,how;
scanf("%d %d",&where,&how);
if((where>count || where<1) && !(count==0&&where==1))
printf("insert fail\n");
else
insert_one(&head,where,how,&count);
}
}
return 0;
}
void add(fushu **phead)
{
int what;
scanf("%d",&what);
fushu *a = (fushu*)malloc(1*sizeof(fushu));
a->value = what;
a->next = NULL;
if(!*phead)
*phead = a;
else
{
a->next = *phead;
*phead = a;
}
}
void print(fushu **phead)
{
if(!*phead) printf("Link list is empty");
else
{
fushu *p = *phead;
for(;p;p=p->next)
printf("%d ",p->value);
}
printf("\n");
}
void del_one(fushu **phead,int x,int *count)
{
fushu *p = *phead;
if(x==1)
{
*phead = p->next;
free(p);
}
else
{
for(int i=1;i<x-1;i++)
p=p->next;
fushu *pp = p->next;
p->next = pp->next;
free(pp);
}
printf("delete OK\n");
(*count)--;
}
void get_one(fushu **phead,int x)
{
fushu *p = *phead;
for(int i=1;i<x;i++)
p=p->next;
printf("%d\n",p->value);
}
void insert_one(fushu **phead,int x,int y,int *count)
{
fushu *a = (fushu*)malloc(1*sizeof(fushu));
a->value = y;
a->next = NULL;
fushu *p = *phead;
if(!p) *phead = a;
else
{
if(x==1)
{
a->next = *phead;
*phead = a;
}
else
{
for(int i=1;i<x-1;i++)
p=p->next;
a->next = p->next;
p->next = a;
}
}
printf("insert OK\n");
(*count)++;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复