全功能链表系统

这是一个使用C语言编写的全功能链表系统,包括创建链表、删除指定节点和输出链表的功能。用户可以选择执行不同的操作,如输入数据创建链表,删除链表中的某个节点(按位置),或者打印链表的所有元素。该系统循环运行,直到用户选择退出。
摘要由CSDN通过智能技术生成
#include <stdio.h>
#include <stdlib.h>
typedef struct node
{
	int data;
	struct node *next;
} Node;

void create(Node *head)   //建立链表
{
	int t;
	Node *s,*r=head;
	printf("请输入链表数据:");
	while(scanf("%d",&t)!=EOF&&t!=0)
	{
		s=(Node *)malloc(sizeof(Node));
		s->data=t ;
		r->next=s;
		r=s;
	}
	r->next=NULL;
}

void delete(Node *head)  //删除第i个元素
{
	int i,j=0;
	Node *p=head,*q;
	printf("要删除第几个结点:");
	scanf("%d",&i); 
	while(j<i-1&&p!=NULL)
	{
		j++;
		p=p->next;
	}
	q=p->next;
	p->next=q->next;
	free(q);

}

void print(Node *head)    //输出线性表
{
	printf("\n");
	Node *p=head->next;
	while(p!=NULL)
	{
		printf("%d ",p->data);
		p=p->next;
	}
	printf("\n");
}

int main()
{
	int a[N];
	int select; 
	Node *head=(Node *)malloc(sizeof(Node));
	head->next=NULL;
	do
	{
		printf("         ----------------全功链表系统----------------\n\n");
		printf("                         1.创建链表(0结束)\n");
		printf("                         2.删除链表结点\n");
		printf("                         3.输出链表\n");
		printf("                         4.退出系统\n\n");
		printf("         ----------------全功链表系统----------------\n\n");
		printf("请选择[ ]\b\b");
		scanf("%d",&select);
		if(select==4)
			break; 
		switch(select)
		{
			case 1:create(head);break;
			case 2:delete(head);break;
			case 3:print(head);break;
		} 
	}while(1);
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值