数据结构---01---顺序表---20205106009---郭睿玥

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
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
/*郭睿玥第一次算法实验作业*/
 
/*实验原理
       顺序表是在计算机内存中以数组的形式保存的线性表,线性表的顺序存储是指
   用一组地址连续的存储单元依次存储线性表中的各个元素、使得线性表中在逻辑结
   构上相邻的数据元素存储在相邻的物理存储单元中,即通过数据元素物理存储的相
   邻关系来反映数据元素之间逻辑上的相邻关系,采用顺序存储结构的线性表通常称
   为顺序表。顺序表是将表中的结点依次存放在计算机内存中一组地址连续的存储单
   元中。
*/
 
/*实验环境
CodeBlocks*/
 
 
/*实验目的
(1) 掌握顺序表的概念及实现方式。
(2) 掌握顺序表的存储结构及主要运算:建立、查找、插入、删除等。*/
 
 
 
/*实验内容
定义一个包含学生信息(学号,姓名,成绩)的顺序表,使其具有如下功能:
(1) 逐个输入学生信息,建立信息表;
(2) 显示信息表中所有学生的相关信息;
(3) 根据姓名进行查找,返回此学生的学号和成绩;
(4) 给定一个学生信息,插入到表中指定的位置;
(5) 删除指定位置的学生记录;
(6) 统计表中学生人数;
(7) 根据自己的理解添加更多的内容。*/
 
 
 
/*算法实现如下*/
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define MAXSIZE 100
 
typedef int Status;// 定义函数返回值类型
typedef int ElemType; // 定义每条数据的结构体类型
 
typedef struct {
    char number[20];// 学号
    char name[20];// 姓名
    int score; // 成绩
} Student;
 
typedef struct {
    Student *elem;// 存储空间的基地址
    int length;// 当前长度
} SqList;
 
SqList L;
 
void build(SqList * L) // 构造空的顺序表 L
{
    L->elem = (Student *) (malloc(sizeof(Student) * MAXSIZE)); //申请空间
    L->length = 0;//空表的长度为0
    if (!L->elem)
        printf("建立顺序表失败\n");
}
 
Status inputsqlist(SqList * L)//按照顺序输入数据
{
    system("cls");//清屏
    int l, n = 0;
    printf("请输入学生的数量:");
    scanf("%d", &l);
    /*依次输入l名学生的数据*/
    while (n < l) {
        if (n >= 100) {
            printf("内存超限\n");
            return 0;
        }
        /*输入第n名学生的数据*/
        printf("第%d位学生信息\n", n + 1);
        printf("\n");
        printf("学号:");
        scanf("%s", L->elem[n].number);//输入学生学号
        printf("-----------------------------\n");
        printf("姓名:");
        scanf("%s", L->elem[n].name);//输入学生姓名
        printf("-----------------------------\n");
        printf("成绩:");
        scanf("%d", &L->elem[n].score);//输入学生成绩
        printf("-----------------------------\n");
        L->length++;//增加数据长度
        n++;
    }
}
 
Status outputsqlist(SqList L)//按照位置显示所有信息
{
    system("cls");//清屏
    int i = 0;
    printf("所有学生的相关信息为:\n\n");//按位置依次显示学生信息
    while (i < L.length) {
        printf("学号:%s    姓名:%s    成绩:%d\n\n", L.elem[i].number, L.elem[i].name, L.elem[i].score);
        i++;
    }
    return 1;
}
 
Status searchsqlist(SqList * L, Student e) //按照姓名对数据搜寻
{
    for (int i = 0; i < L->length + 1; i++) {
        if (!strcmp(L->elem[i].name, e.name)) //比较需要查找的值与
            return i + 1;
    }
}
 
Status locatesqlist(SqList L)//按照姓名查找
{
    system("cls");//清屏
    Student e;//需要查找的数据
    int temp;//中间量
    printf("请输入你要查找的姓名:");
    scanf("%s", e.name);//输入需要查找的数据的姓名
    temp = searchsqlist(&L, e);
    if (temp != 0)         /*如果找到数据则输出该条数据的全部内容*/
        printf("学号:%s 成绩:%d\n\n", L.elem[temp - 1].number, L.elem[temp - 1].score);
    else                   /*如果没有找到与已经存入的数据相同的数据显示失败*/
        printf("查找失败!\n\n");
    return 1;
}
 
Status insersqlist(SqList * L)//插入学生信息
{
    system("cls");//清屏
    int i, k = 0;//i是要插入的位置
    Student e;
    printf("请输入你要插入的位置:");
    scanf("%d", &i);
/*↓↓在L中第i个位置之前插入新的数据元素e,L的长度加1↓↓*/
    if(i<1 || i > L->length + 1)     /*不允许在第0个数据之前或者最后一个后的数据之后插入数据*/
    {
        printf("插入位置有误\n");
        return 0;
    }
 
 
    if (L->length >= MAXSIZE) {
        printf("数据溢出\n");
        return 0;
    }
 
    printf("请输入插入学生信息:\n"); /*输入所需要插入的学生的数据*/
    printf("学号:");
    scanf("%s", e.number);
    printf("姓名:");
    scanf("%s", e.name);
    printf("成绩:");
    scanf("%d", &e.score);
 
    if (i == L->length + 1) {/*如果插入的元素在最后一位则只用在最后的位置输入数据无需移动其他数据的位置 */
        L->elem[i - 1] = e;//使最后的数据改变为所要插入的数据
        L->length++;//长度加1
        return 1;
    }
 
    for (k = L->length - 1; k >= i - 1; --k)/*从最后一个元素开始每个元素向后移动位置并且长度改变 */
        L->elem[k + 1] = L->elem[k];//第k+1元素后移
    L->elem[i - 1] = e;////使第i改变为所要插入的数据
    L->length++;//长度加1
    return 1;
}
 
Status deletesqlist(SqList * L) //删除指定位置学生记录
{
    system("cls");//清屏
    int i, j = 0, k;//i指要删除的数据的位置,j指循环的次数,k指当前循环次数所对应的元素的位置
    printf("请输入要删除学生的位置:");
    scanf("%d", &i);
    if (i == 0 || i > L->length) {//如果需要删除数据的位置没有数据则删除失败
        printf("删除失败");
        return 0;
    }
    while (j <= L->length) {
        if (L->length != j)                   //定位需要删除的数据
            j++;
        else {
            for (k =i; k < L->length; k++)
                L->elem[k - 1] = L->elem[k];  //将后面元素依次前移
            L->length--;//长度减1
            break;
        }
    }
}
 
Status sumsqlist(SqList * L)                    //显示学生总数
{
    int sum = 0;
    sum = L->length;//结构体SqList中的length表示数据的条数
    printf("总学生个数为:%d\n\n", sum);
    return 1;
}
 
int main()
{
    int choice;
    build(&L);//调用函数建立一个空表
    do {/*显示操作界面*/
        printf("********************************************************************\n");
        printf("*      1. 根据指定学生个数,逐个输入学生信息,建立信息表;          *\n");
        printf("*      2. 显示学生表中所有学生的相关信息;                         *\n");
        printf("*      3. 根据姓名进行查找,返回此学生的学号和成绩;               *\n");
        printf("*      4. 给定一个学生信息,插入到表中指定的位置;                 *\n");
        printf("*      5. 删除指定位置的学生记录;                                 *\n");
        printf("*      6. 统计表中学生个数;                                       *\n");
        printf("*      0. 退出。                                                   *\n");
        printf("********************************************************************\n");
        printf("*      郭睿玥算法第2次作业                                         *\n");
        printf("\n");
        printf("请选择你要操作的选项:");
        scanf("%d", &choice);//输入需要进行的选项
        printf("\n");
        system("cls");//清屏
        switch (choice) {
        case 1:{
                inputsqlist(&L);//调用函数依位置输入数据
                break;
            }
        case 2:{
                outputsqlist(L);//调用函数按位置的前后输出数据
                break;
            }
        case 3:{
                locatesqlist(L);//调用函数按照姓名查找学生信息
                break;
            }
        case 4:{
                insersqlist(&L);//调用函数按照位置插入学生信息
                break;
            }
        case 5:{
                deletesqlist(&L);//调用函数按照删除指定位置学生信息
                break;
            }
        case 6:{
                sumsqlist(&L);//调用函数统计学生总数
                break;
            }
        case 0:{
                printf("\n退出系统成功!请按任意键结束!\n");//退出程序
                exit(0);
            }
            break;
        }
    } while (choice);//只要选择不为需要进行的功能不为0则该程序可以一直进行下去
}
 
/*运行结果
操作界面如下
 
1. 根据指定学生个数,逐个输入学生信息,建立信息表;
2. 显示学生表中所有学生的相关信息;
3. 根据姓名进行查找,返回此学生的学号和成绩;
4. 给定一个学生信息,插入到表中指定的位置;
5. 删除指定位置的学生记录;
6. 统计表中学生个数;
0. 退出。
郭睿玥 算法与数据结构第一次作业
 
(以下内容中操作界面的显示已经省略)
输入
请选择你要操作的选项:1
请输入学生的数量:5
学号;111
姓名;aaa
成绩;60
学号;222
姓名;bbb
成绩;70
学号;333
姓名;ccc
成绩;80
学号;444
姓名;ddd
成绩;50
学号;555
姓名;eee
成绩;40
请选择你要操作的选项:2
显示为
学号;111 姓名;aaa 成绩;60
学号;222 姓名;bbb 成绩;70
学号;333 姓名;ccc 成绩;80
学号;444 姓名;ddd 成绩;50
学号;555 姓名;eee 成绩;40
输入
请选择你要操作的选项:3
你要查找的姓名;ccc
显示为学号;333 成绩;80
请选择你要操作的选项:4
请选择你要插入的位置:6
学号:888 姓名;fff 成绩;88
请选择你要操作的选项:5
你要删除的位置;1
请选择你要操作的选项:6
总学生个数为:5
请选择你要操作的选项:2
学号;222 姓名;bbb 成绩;70
学号;333 姓名;ccc 成绩;80
学号;444 姓名;ddd 成绩;50
学号;555 姓名;eee 成绩;40
学号;666 姓名;fff 成绩;88
请选择你要操作的选项:0
退出系统成功!
*/

 

posted @   张同光  阅读(197)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
历史上的今天:
2020-10-24 brunch dipper --- error
点击右上角即可分享
微信分享提示