服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C语言实现简易订餐系统

C语言实现简易订餐系统

2022-12-25 16:18孤鹜_ C/C++

这篇文章主要为大家详细介绍了C语言实现简易订餐系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现简易订餐系统的具体代码,供大家参考,具体内容如下

主要功能:

(1)菜单维护(餐厅管理人员使用)采用顺序表实现

1、添加新菜

2、删除菜品

3、修改菜品信息

4、打印现有的菜品信息

(2)点餐(客户使用)  采用链表实现

1、订单菜品添加、删除、显示

2、计算显示订单总价.........

对此我们可以创建一个结构体类型,并将其重命名为ElemType,结构体里面存放有id,name,price分别表示菜品的id号,菜名和价格。接着分别定义一个顺序表和链表。接着我们就可以开始实现代码啦!

C语言实现简易订餐系统

这里我采用的是多文件编程的方式,总共包含七个文件,三个.h文件,四个.c文件。

你只需要创建一个工程,然后分别创建下列七个文件并命名好就可以啦。

main.c文件中代码如下:

?
1
2
3
4
5
6
7
#include"run.h"
 
int main()
{
    run_init();
    return 0;
}

main函数里只调用了一个run_init()函数

run.h文件代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
#ifndef __RUN_H
#define __RUN_H
 
#include"list.h"
#include"link.h"
 
void run_init();
SqList * menu_mt(SqList * List);
void menu_help();
Link_Node * order_mt(Link_Node *Head,SqList *List);
void order_help();
 
#endif

run.c文件代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#include"run.h"
#include"stdlib.h"
void run_init()
{
    int a;
    SqList * List;
    Link_Node * Head;
    while(1)
    {
        printf("\t\t****输入1进入菜单维护模式****\n\t\t****输入2进入点餐模式****\n");
        printf("\t\t****输入3退出程序****\n");
        printf("请进行模式选择:\n");
        scanf("%d",&a);
        switch(a)
        {
            case 1: List = menu_mt(List);break;
            case 2: Head = order_mt(Head,List);break;  
            case 3: printf("谢谢使用本程序!期待下次与你会见!\n");
            if(List != NULL) free(List);return ;  //结束程序
            default:printf("error,没有这个选项!请重新选择!\n");break;
        }
    }
}
 
SqList * menu_mt(SqList * List)
{
    int flag = 1,a;//flag为退出标志
    while(flag)
    {
        menu_help();
        printf("请进行模式选择:");
        scanf("%d",&a);
        switch(a)
        {
            case 1:List = Create_List();break;
            case 2:       Display_List(List);break;
            case 3:List = Add_List(List);break;
            case 4:List = Delete_List(List);break;
            case 5:List = Updata_List(List);break;
            case 6:flag = 0;break;
            default:printf("error,没有这个选项,请重新选择!\n");break;
        }
    }
    printf("已成功退出菜单维护模式!\n");
    return List;
}
 
void menu_help()
{
    printf("\t\t******1------>创建菜单表------******\n");
    printf("\t\t******2------>打印菜单表------******\n");
    printf("\t\t******3------> 添加菜品 ------******\n");
    printf("\t\t******4------> 删除菜品 ------******\n");
    printf("\t\t******5------> 修改菜品 ------******\n");
    printf("\t\t******6------> 返回上级 ------******\n");
}
 
void order_help()
{
    printf("\t\t******1------>开始点餐(创建链表)------******\n");
    printf("\t\t******2------> 显示所有菜品信息 ------******\n");
    printf("\t\t******3------>   订单菜品添加   ------******\n");
    printf("\t\t******4------>   订单菜品删除   ------******\n");
    printf("\t\t******5------> 显示已点菜品信息 ------******\n");
    printf("\t\t******6------>   计算订单价格   ------******\n");
    printf("\t\t******7------>     返回上级     ------******\n");
}
 
Link_Node * order_mt(Link_Node *Head,SqList *List)
{
    int flag = 1,a;//flag为退出标志
    while(flag)
    {
        order_help();
        printf("请进行模式选择:");
        scanf("%d",&a);
        switch(a)
        {
            case 1:Head = Create_Link(Head);break;
            case 2:       Display_List(List);break;
            case 3:Head = Add_Link(Head,List);break;
            case 4:Head = Delete_Link(Head);break;
            case 5:       Display_Link(Head);break;
            case 6:       Count_Link(Head);break;
            case 7:flag = 0;break;
            default:printf("error,没有这个选项,请重新选择!\n");break;
        }
    }
    Destory_Link(Head);
    printf("已成功退出点餐模式!\n");
    return Head;
}

link.h代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#ifndef __LINK_H
#define __LINK_H
 
#include "list.h"
 
typedef struct LNode
{
    ElemType data;
    struct LNode *next;
}Link_Node;
 
Link_Node *Create_Link(Link_Node * Head);
Link_Node *Add_Link(Link_Node *Head,SqList *List);
Link_Node *Delete_Link(Link_Node *Head);
void Count_Link(Link_Node *Head);
void Display_Link(Link_Node *Head);
void Destory_Link(Link_Node *Head);
#endif

link.c代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#include"link.h"
#include "stdlib.h"
 
//创建链表
Link_Node *Create_Link(Link_Node * Head)
{
    Head = (Link_Node*)malloc(sizeof(Link_Node));
    if(Head == NULL)
        printf("申请空间失败!\n");
    else
    {
        Head->next = NULL;
        printf("订单申请成功,您现在可以开始点餐啦!\n");
    }
    return Head;
}
 
//添加结点
Link_Node *Add_Link(Link_Node *Head,SqList *List)
{
    int id_input,a;
    Link_Node *Ptemp = NULL;
    Ptemp = (Link_Node*)malloc(sizeof(Link_Node));
    if(Ptemp == NULL)
        printf("申请空间失败!\n");
    else
    {
        printf("输入你想添加菜品的id:");
        scanf("%d",&id_input);
        a = Searchid_List(List,id_input);
        if(a == -1)
        {
            printf("暂时还没有这个菜呀,请您重新选择。\n");
        }
        else
        {
             Ptemp->data = List->data[a];
            Ptemp->next = Head->next;
            Head->next = Ptemp;
            printf("菜品已成功添加到您的订单!\n");
        }
    }
    return Head;
}
 
//删除结点
Link_Node *Delete_Link(Link_Node *Head)
{
    int id_input;
    Link_Node *Pt=Head->next,*Pq=Head;
    printf("请输入你想删除菜品的id:");
    scanf("%d",&id_input);
    while (Pt!=NULL)
    {
        if(id_input == (Pt->data).id) //找到便删除
        {
            Pq->next = Pt->next;
            free(Pt);
            printf("已成功删除!\n");
            break;
        }
        Pt = Pt->next;
        Pq = Pq->next;//向后走链
    }
    if(Pt==NULL)
    {
        printf("删除失败,您的订单中没有这个菜喔.\n");
    }
    return Head;
}
 
//打印订单
void Display_Link(Link_Node *Head)
{
    Link_Node *Pt=Head->next;
    printf("已点菜品如下:\n");
    while (Pt!=NULL)
    {
        printf("id:%d\t",(Pt->data).id);
        printf("name:%s\t",(Pt->data).name);
        printf("price:%d\n",(Pt->data).price);
        Pt = Pt->next;
    }  
}
 
//计算订单总价
void Count_Link(Link_Node *Head)
{
    int sum = 0;
    Link_Node *Pt=Head->next;
    while (Pt!=NULL)
    {
        sum += (Pt->data).price;
        Pt = Pt->next;
    }
    printf("您的订单总价格为:%d元\n",sum);
}
 
//销毁链表
void Destory_Link(Link_Node *Head)
{
     Link_Node *Pt=Head;
     while(Head!=NULL)
     {
        Head = Head->next;
        free(Pt);
        Pt = Head;
     }
     printf("链表空间已释放!\n");
}

list.h文件代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
#ifndef __LIST_H
#define __LIST_H
 
#include "stdio.h"
#define MaxSize 100
typedef struct
{
    int id;
    char name[50];
    int price;
}ElemType;
 
typedef struct
{
    ElemType data[MaxSize];
    int length;
}SqList;
 
SqList * Create_List();
void input_one(SqList *List,int i);
void Display_List(SqList *List);
SqList *  Add_List(SqList *List);
SqList * Delete_List(SqList *List);
SqList * Updata_List(SqList *List);
int Searchid_List(SqList *List,int id_input);
int Searchname_List(SqList *List,char *name_input);
int mode_choose(SqList *List);
 
#endif

list.c文件代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
#include "list.h"
#include "stdlib.h"
#include "string.h"
 
//创建顺序表并初始化
SqList * Create_List()
{
    int num;
    SqList * List;
    List = (SqList*)malloc(sizeof(SqList));
    if(List == NULL)
    {
        printf("申请空间失败!\n");
        return 0;
    }
    printf("请输入你要初始化的菜品个数:");
    scanf("%d",&num);
    if(num == 0)
    {
        printf("初始化错误!\n");
        free(List);
        return 0;
    }
    for(int i=0;i<num;i++)
    {
       input_one(List, i);
    }
    List->length = num;
    return List;
}
 
//输入一个菜品信息
void input_one(SqList *List,int i)
{
    int flag = 0;//flag=0表示第一次输入id、name
    int id_temp;
    char name_temp[50];
     do{
            if(flag)
                printf("输入的id已被占用,请重新输入!\n");
            flag = 1;
            printf("请输入第%d个菜品的id:",i+1);
            scanf("%d",&id_temp);  
        }while( Searchid_List(List,id_temp) != -1); //没找到返回-1
 
        (List->data[i]).id = id_temp;
        flag = 0; //flag=0表示第一次输入id、name
         do{
            if(flag)
                printf("输入的name已被占用,请重新输入!\n");
            flag = 1;
             printf("请输入第%d个菜品的名字:",i+1);
             scanf("%s",name_temp);
        }while( Searchname_List(List,name_temp) != -1);  //没找到返回-1
 
        strcpy((List->data[i]).name, name_temp);
        printf("请输入第%d个菜品的价格:",i+1);
        scanf("%d",&(List->data[i]).price);
}
//打印顺序表中所有信息
void Display_List(SqList *List)
{
    int len = List->length;
    printf("已有如下菜品:\n");
    for(int i=0;i<len;i++)
    {
        printf("id:%d\t",(List->data[i]).id);
        printf("name:%s\t",(List->data[i]).name);
        printf("price:%d\n",(List->data[i]).price);
    }
}
 
//添加一个新菜品
SqList *  Add_List(SqList *List)
{
    int i = List->length;
    if(i==MaxSize)
    {
        printf("空间已满,正在返回上级\n");
        return List;
    }
    Display_List(List);
    input_one(List, i);
    (List->length)++;
    return List;
}
 
int mode_choose(SqList *List)
{
    int a,flag = 1;
    while(flag)
    {
        printf("******1---->  按id删除/修改  ----******\n");
        printf("******2----> 按name删除/修改 ----******\n");
        printf("******3---->  退出删除/修改  ----******\n");
        printf("请进行模式选择:");
        scanf("%d",&a);
        switch(a)
        {
            case 1: return Searchid_List(List,-1);break;
            case 2: return Searchname_List(List,"-1");break;
            case 3:flag = 0;break;
            default:printf("error,没有这个选项请重新选择!\n");break;
        }
    }
    return -2;  //取消删除/修改 返回上级
}
 
//删除一个菜品
SqList * Delete_List(SqList *List)
{
    int a; //用来保存找到的下标
    a = mode_choose(List);
    if(a == -1)
    {
        printf("没有查询到这个id/name!\n");
    }
    else if(a == -2)
    {
        printf("正在返回上一级!\n");
    }
    else
    {
        for(int i=a;i<List->length - 1;i++)  //前移删除
        {
            List->data[i] = List->data[i+1];
        }
        (List->length)-- ;
        printf("删除成功!\n");
    }
    return List;
}
 
//修该菜品
SqList * Updata_List(SqList *List)
{
    int a,flag = 0; //用来保存找到的下标
    a = mode_choose(List);
    if(a == -1)
    {
        printf("没有查询到这个id/name!\n");
    }
    else if(a == -2)
    {
        printf("正在返回上一级!\n");
    }
    else
    {
        printf("原菜品信息为:");
        printf("id:%d\t",(List->data[a]).id);
        printf("name:%s\t",(List->data[a]).name);
        printf("price:%d\n",(List->data[a]).price);
        input_one(List, a);
    }
    return List;
}
 
//按id查找  id_input == -1为输入查找  否则为传参查找
int Searchid_List(SqList *List,int id_input)
{
    int ret = -1;
    if(id_input == -1)
    {
        printf("请输入你想查询并修改/删除的id:");
        scanf("%d",&id_input);
    }
    for(int i=0;i<List->length;i++)
    {
        if((List->data[i]).id == id_input)
        {
            ret = i;   //找到返回下标
            break;
        }
    }
    return ret; //没找到
}
 
//按菜名查找
int Searchname_List(SqList *List,char *name_input0)
{
    int ret = -1;
    char name_input1[50];
    if(strcmp(name_input0,"-1")==0)
    {
        printf("请输入你想查找并修改/删除的name:");
        scanf("%s",name_input1);
    }
    else
    {
        strcpy(name_input1,name_input0);
    }
    for(int i=0;i<List->length;i++)
    {
        if(strcmp( (List->data[i]).name, name_input1) == 0 )
        {
            ret = i;   //找到返回下标
            break;
        }
    }
    return ret;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/weixin_52778075/article/details/121429579

延伸 · 阅读

精彩推荐
  • C/C++关于C++运算符重载的一些困惑详解

    关于C++运算符重载的一些困惑详解

    这篇文章主要给大家介绍了关于C++运算符重载的一些困惑,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋...

    bruce62811452021-11-02
  • C/C++C++实现班级成绩管理系统

    C++实现班级成绩管理系统

    这篇文章主要为大家详细介绍了C++实现班级成绩管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    bosh_rong8772022-10-08
  • C/C++Visual Studio Code (vscode) 配置C、C++环境/编写运行C、C++的教程详解(主要Windows、简要Linux)

    Visual Studio Code (vscode) 配置C、C++环境/编写运行C、C++的教程详解(

    这篇文章主要介绍了Visual Studio Code (vscode) 配置C、C++环境/编写运行C、C++(主要Windows、简要Linux),本文通过实例截图给大家介绍的非常详细,对大家的学习...

    bat674512021-08-27
  • C/C++Qt基础开发之Qt多线程类QThread与Qt定时器类QTimer的详细方法与实例

    Qt基础开发之Qt多线程类QThread与Qt定时器类QTimer的详细方法与实例

    这篇文章主要介绍了Qt基础开发之Qt多线程类QThread与Qt定时器类QTimer的详细方法与实例,需要的朋友可以参考下...

    吓人的猿4702021-08-25
  • C/C++C语言版简单扫雷游戏

    C语言版简单扫雷游戏

    这篇文章主要为大家详细介绍了C语言版简单扫雷游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    翔哥爱编程12462021-12-20
  • C/C++C++string中的insert()插入函数详解

    C++string中的insert()插入函数详解

    这篇文章主要介绍了C++string中的insert()插入函数,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以...

    信小颜9332021-08-25
  • C/C++如何用C++实现A*寻路算法

    如何用C++实现A*寻路算法

    寻路是游戏比较重要的一个组成部分。因为不仅AI还有很多地方(例如RTS游戏里操控人物点到地图某个点,然后人物自动寻路走过去)都需要用到自动寻路的功...

    KillerAery5852021-11-15
  • C/C++详解C标准库堆内存函数

    详解C标准库堆内存函数

    在C/C++语言中,我们知道内存分为这几种:程序全局变量内存、栈内存、堆内存。其中堆内存就是通过malloc(new)来分配的内存,本文我们来探讨一下C标准库...

    可可西9172021-11-12