c语言单链表订票,单链表的基本操作C语言

本文目录一览:

C语言的题目—试设计一个航空客运订票系统

白痴,这个问题至少200分,我以前的比这个简单的200分也没人回答

#include stdio.h

#include string.h

#include conio.h

#include ctype.h

#include stdlib.h

#include malloc.h

#include math.h//overflow

#define ok 1

typedef struct Yidingkehu

{//单链表

char name[15];//已订票的客户姓名

int dingpiaoshu;//已订票数量

struct Yidingkehu *next1;//

}Yidingkehu,*Link;

typedef struct Weidingkehu

{//单链队

char name[15];//预订票的客户姓名

int yudingpiao;// 要订票数量

struct Weidingkehu *next2;//下一个链队结点指针

}Weidingkehu,*Qptr;

typedef struct Hangxian

{//创建一个含有六个信息的结构体

char hangbanhao[15];//航班号-

char feijihao[15];//飞机号

int feixingriqi;//起飞时间

int chenkerenshu;//座位数

int yupiao;//余票

char zhongdianzhai[15];//降落城市

struct Hangxian *next;//指向下一个链结点的指针

struct Yidingkehu *yiding;//定义一个指向已订票客户的头结点指针

struct Weidingkehu *yudingqueue;

}Hangxian,*Linklist;

Linklist InitLinklist();//01

int InsertLinklist(Linklist head1);//02

void hbhchaxun();//通过航班号查询

void mddchaxun();//通过目的地查询

void lurugongneng();//初始化录入功能

void chaxungongnen();//查询功能

void dingpiaogongnen();//订票功能

void tuipiaogongnen();//退票功能

void main()

{

int n;

do{ //打印主界面

printf(“\t 欢迎使用航空客运订票系统\n”);

printf(“\t+++++++++++++++++++++++++++++\n”);

printf(“\t==1. 录入功能 ==\n”);

printf(“\t==2. 查询功能 ==\n”);

printf(“\t==3. 订票功能 ==\n”);

printf(“\t==4. 退票功能 ==\n”);

printf(“\t==5. 退出 ==\n”);

printf(“\t+++++++++++++++++++++++++++++\n”);

printf(“\t请选择:”);

scanf(“%d”,n);printf(“\n”);

switch(n)

{

case 1: lurugongneng();//录入功能

break;

case 2: chaxungongnen();//查询功能

break;

case 3: dingpiaogongnen();//订票功能

break;

case 4:tuipiaogongnen();//退票功能

break;

default :exit(0);//退出

}

}while(n==1||n==2||n==3||n==4);

}

void lurugongneng()//初始化的单链表*********************************************************录入功能

{

Linklist p;

//int m,n;

if(!p) exit(OVERFLOW);

printf(“\t请依次输入下面几项内容:\n\n”);//这里的输入采用一个个单独输入,避免了乱赋值的现象

printf(“航班号\n”);

gets(p-hangbanhao);//这里的二个gets主要是因为在回车键的输入,其中的第一个是来接收上次的回车

gets(p-hangbanhao);

printf(“飞机号\n”);

gets(p-feijihao);

printf(“终点站\n”);

gets(p-zhongdianzhai);

printf(“飞行日期\n”);

scanf(“%d”,p-feixingriqi);

printf(“乘客总数\n”);

scanf(“%d”,p-chenkerenshu);

printf(“余票数\n”);

scanf(“%d”,p-yupiao);

}

void chaxungongnen()//******************************************************************查询功能

{

int n;

printf(“\t 查 找 航 线 信 息 \n”);

printf(“\t+++++++++++++++++++++++++++++\n”);

printf(“\t==1. 通过目的地查询 ==\n”);

printf(“\t==2. 通过航班号查询 ==\n”);

printf(“\t+++++++++++++++++++++++++++++\n”);

printf(“\t请选择:”);

scanf(“%d”,n);

printf(“\n”);//格式化

switch(n)

{

case 1:mddchaxun();

break;

case 2:hbhchaxun();

break;

default :break;

}

}

void mddchaxun()//通过目的地查询

{

char c[15];

int m;

Linklist p=L;

printf(“\t请输入要查询的目的地:”);

gets(c);

gets(c);//原因同上

do{

p=p-next;

if(p)

{

m=strcmpi((*p).zhongdianzhai,c);//如果==的话则m=0;

if(m==0)

{

printf(“\t航班信息:\n”);

printf(“\t航班号:%s\n”,p-hangbanhao);

printf(“\t飞机号:%s\n”,p-feijihao);

printf(“\t飞行时间:周%d\n”,p-feixingriqi);

printf(“\t余票量:%d\n”,p-yupiao);

}

}

else

{//如果不匹配的话就做

printf(“\t对不起没有你要找的目的地:\n\n”); m=0;

}

}while(m!=0);

}

void hbhchaxun()//通过目的地查询

{

char c[15];

int m;

Linklist p=L;

printf(“\t请输入要查询的航班号:”);

gets(c); gets(c);printf(“\n”);

do{

p=p-next;

if(p)

{

m=strcmpi((*p).hangbanhao,c);//如果==的话则m=0;这里的(*p).与p-的作用是一样的

if(m==0)

{

printf(“\t航班信息:\n”);

printf(“\t航班号:%s\n”,p-hangbanhao);

printf(“\t飞机号:%s\n”,p-feijihao);

printf(“\t飞行时间:周%d\n”,p-feixingriqi);

printf(“\t余票量:%d\n\n”,p-yupiao);

}

}

else

{//如果不匹配的话就做

printf(“\t对不起没有你要找的航班号:\n”); m=0;

}

}while(m!=0);

}

void dingpiaogongnen()//***************************************************************订票功能

{

char c[15];

int m=1,piao,ydpiao=0,yd=0,n;//

gets(c);

printf(“请输入终点站名:”); gets(c); printf(“\n”);

p=L-next;

if(p) {

do{//查找一下,是否有这个航班

if(!p)

{

printf(“对不起,没有你要找的航班:\n\n”);

goto loop1;

}

m=strcmpi(p-zhongdianzhai,c);

if(m==0)

{

printf(“航班信息:\n”);

printf(“航班号:%s\n”,p-hangbanhao);

printf(“飞机号:%s\n”,p-feijihao);

printf(“飞行时间:周%d\n”,p-feixingriqi);

printf(“余票量:%d\n”,p-yupiao);}

else p=p-next;

}while(m!=0);

if(m==0)

{

do{

printf(“\n请输入你要订的票数:”); scanf(“%d”,piao);

if(piao=p-yupiao)

{

h=p-yiding;

if(h)

{

h1=h;

h=h-next1;

h=(struct Yidingkehu*)malloc(sizeof(Yidingkehu));

printf(“请输入你的名字:”);

gets(h-name);gets(h-name);

h-dingpiaoshu=piao;

h-next1=h1-next1;

h1-next1=h;

p-yupiao=p-yupiao-piao;

printf(“订票成功:\n”); m=2;

}

}

else

{

printf(“余票量:%d\n”,p-yupiao);

printf(“对不起,余票 %d 张不足,不能完成订票\n\n”,p-yupiao);

printf(” 是否要重新订票?\n”);

printf(“需要请输入1 否则请按2 预订请输入3 : “);

scanf(“%d”,m);

printf(“\n”);

if(m==3) goto loop3;

}

}while(m==1);

}

}

else if(!p)

{

loop3: struct Weidingkehu *q3;

printf(“对不起,该航班的票已售完\n”);

q.front=p-yudingqueue;

if(q.front==q.rear) printf(“没有人预订票,是否要预订?\n”);

else if(q.front!=q.rear) printf(“已有人预订票,是否要预订?\n”);

printf(“预订请输入1 否则输入2 : “);

scanf(“%d”,n);

printf(“\n”);

if(n==1)

{

printf(“请输入你的姓名”); gets(q3-name); gets(q3-name);//q3不能指向name???

printf(“请输入订票数”); scanf(“%d”,q3-yudingpiao);

q3-next2=NULL;

q.rear-next2=q3;

q.rear=q3;

printf(” 你已经预订了 !\n”);

}

}

loop1:;

}

void tuipiaogongnen()//***************************************************************退票功能

{

}

用C语言实现对单链表的基本操作

#include stdio.h

#include stdlib.h

typedef int DataType;

typedef struct node {

DataType member;

struct node *next;

}*LinkList, *pNode;

// 初始化链表

LinkList GetEmptyList() {

LinkList head = (pNode)malloc(sizeof(struct node));

head-member = 0;

head-next = NULL;

return head;

}

// 在非增链表中插入结点

void InsertNode(LinkList head, DataType x) {

pNode p,q;

for(p = head; p-next != NULL; p = p-next) {

if(p-next-member = x) {

q = (pNode)malloc(sizeof(struct node));

q-member = x;

q-next = p-next;

p-next = q;

return;

}

}

q = (pNode)malloc(sizeof(struct node));

q-member = x;

q-next = p-next;

p-next = q;

}

// 新结点插入为首结点

void PushNode(LinkList head, DataType x) {

pNode p = (pNode)malloc(sizeof(struct node));

p-member = x;

p-next = head-next;

head-next = p;

}

// 删除结点

int DeleteNode(LinkList head, DataType x) {

pNode p,q;

for(p = head; p != NULL; p = p-next) {

if(p-next-member == x) {

q = p-next;

p-next = q-next;

free(q);

return 1; // 成功删除member(第一个)为x的结点

}

}

return 0; // 没有找到member为x的结点

}

// 查找结点

int FindNode(LinkList head, DataType x) {

pNode p;

for(p = head-next; p != NULL; p = p-next) {

if(p-member == x) return 1; // 找到了

}

return 0; // 没有找到

}

// 销毁链表

void DestroyList(LinkList head) {

pNode q,p = head;

while(p) {

q = p;

p = q-next;

free(q);

}

head = NULL;

}

// 遍历链表

void ShowList(LinkList head) {

pNode p = head-next;

while(p != NULL) {

printf(“%d “,p-member);

p = p-next;

}

printf(“\n”);

}

int main() {

DataType x,res;

LinkList head = GetEmptyList();

printf(“输入一个整数(‘q’ to quit): “);

while(scanf(“%d”,x) == 1) {

InsertNode(head, x); // 创建非增链表

printf(“输入一个整数(‘q’ to quit): “);

}

fflush(stdin);

ShowList(head);

printf(“输入待查找的整数: “);

scanf(“%d”,x);

res = FindNode(head, x);

if(res) printf(“找到了。\n”);

else printf(“没找到!\n”);

printf(“输入待删除的整数: “);

scanf(“%d”,x);

res = DeleteNode(head, x);

if(res) printf(“成功删除。\n”);

else printf(“没找到数据为:%d的结点!\n”,x);

ShowList(head);

DestroyList(head);

return 0;

}

C语言如何创建单链表?

C语言创建单链表如下:

#include”stdio.h”

#include”stdlib.h”

#include”malloc.h”

#include “iostream.h”

typedef struct node

{

int  data;

node * next;

}node , * List;

void create(int n)

{

int c;

List s,L;

L=(List)malloc(sizeof(node));

L-next=NULL;

printf(“请输入第1个数据:”);

scanf(“%d”,c);

L-data=c;

for(int i=2;i=n;i++)

{

s=(List)malloc(sizeof(node));

printf(“请输入第%d个数据:”,i);

scanf(“%d”,c);

s-data=c;

s-next=L;

L-next =s;

}

printf(“链表创建成功!”);

}

void main()

{

int n;

printf(“请你输入链表的个数:”);

scanf(“%d”,n);

create(n);

}

单链表创建方法:

单链表的建立有头插法、尾插法两种方法。

1. 头插法

单链表是用户不断申请 存储单元和改变链接关系而得到的一种特殊 数据结构,将链表的左边称为链头,右边称为链尾。头插法建单链表是将链表右端看成固定的,链表不断向左延伸而得到的。头插法最先得到的是尾结点。

由于链表的长度是随机的,故用一个while循环来控制链表中结点个数。假设每个结点的值都大于O,则循环条件为输入的值大于o。申请 存储空间可使用malloc()函数实现,需设立一申请单元 指针,但malloc()函数得到的指针并不是指向 结构体的指针,需使用 强制类型转换,将其转换成结构体型指针。刚开始时,链表还没建立,是一空链表,head 指针为NULL。

链表建立的过程是申请空间、得到数据、建立链接的循环处理过程。

2. 尾插法

若将链表的左端固定,链表不断向右延伸,这种建立链表的方法称为尾插法。尾插法建立链表时,头 指针固定不动,故必须设立一个搜索指针,向链表右边延伸,则整个算法中应设立三个链表指针,即头指针head、搜索指针p2、申请单元指针pl。尾插法最先得到的是 头结点。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/251806.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-13 17:32
下一篇 2024-12-13 17:32

相关推荐

  • 利用Python实现两个链表合并为一个有序链表

    对于开发工程师来说,实现两个链表合并为一个有序链表是必须掌握的技能之一。Python语言在链表处理上非常便利,本文将从多个方面详细阐述如何利用Python实现两个链表合并为一个有序…

    编程 2025-04-29
  • Python栈操作用法介绍

    如果你是一位Python开发工程师,那么你必须掌握Python中的栈操作。在Python中,栈是一个容器,提供后进先出(LIFO)的原则。这篇文章将通过多个方面详细地阐述Pytho…

    编程 2025-04-29
  • AES加密解密算法的C语言实现

    AES(Advanced Encryption Standard)是一种对称加密算法,可用于对数据进行加密和解密。在本篇文章中,我们将介绍C语言中如何实现AES算法,并对实现过程进…

    编程 2025-04-29
  • 学习Python对学习C语言有帮助吗?

    Python和C语言是两种非常受欢迎的编程语言,在程序开发中都扮演着非常重要的角色。那么,学习Python对学习C语言有帮助吗?答案是肯定的。在本文中,我们将从多个角度探讨Pyth…

    编程 2025-04-29
  • Python操作数组

    本文将从多个方面详细介绍如何使用Python操作5个数组成的列表。 一、数组的定义 数组是一种用于存储相同类型数据的数据结构。Python中的数组是通过列表来实现的,列表中可以存放…

    编程 2025-04-29
  • Python被称为胶水语言

    Python作为一种跨平台的解释性高级语言,最大的特点是被称为”胶水语言”。 一、简单易学 Python的语法简单易学,更加人性化,这使得它成为了初学者的入…

    编程 2025-04-29
  • Python操作MySQL

    本文将从以下几个方面对Python操作MySQL进行详细阐述: 一、连接MySQL数据库 在使用Python操作MySQL之前,我们需要先连接MySQL数据库。在Python中,我…

    编程 2025-04-29
  • OpenJudge答案1.6的C语言实现

    本文将从多个方面详细阐述OpenJudge答案1.6在C语言中的实现方法,帮助初学者更好地学习和理解。 一、需求概述 OpenJudge答案1.6的要求是,输入两个整数a和b,输出…

    编程 2025-04-29
  • Python磁盘操作全方位解析

    本篇文章将从多个方面对Python磁盘操作进行详细阐述,包括文件读写、文件夹创建、删除、文件搜索与遍历、文件重命名、移动、复制、文件权限修改等常用操作。 一、文件读写操作 文件读写…

    编程 2025-04-29
  • Python代码实现回文数最少操作次数

    本文将介绍如何使用Python解决一道经典的回文数问题:给定一个数n,按照一定规则对它进行若干次操作,使得n成为回文数,求最少的操作次数。 一、问题分析 首先,我们需要了解回文数的…

    编程 2025-04-29

发表回复

登录后才能评论