目 录
第一部分 预备知识 ....................................................................................................... 1
预备知识 ............................................................................................................... 1 预备知识实验 ......................................................................................................... 2 第二部分 基础实验 ....................................................................................................... 4
实验1 线性表的基本操作 ..................................................................................... 4 实验2 链表的基本操作 ......................................................................................... 9 实验3 栈的基本操作 .......................................................................................... 15 实验4 队列的基本操作 ....................................................................................... 22 实验5 数组的基本操作 ....................................................................................... 32 实验6 字符串的基本操作 ................................................................................... 36 实验7 二叉树的基本操作 ................................................................................... 41 实验8 树的遍历和哈夫曼树 ................................................................................ 46 实验9 图的基本操作 .......................................................................................... 53 实验10 排 序................................................................................................... 59 实验11 查 找................................................................................................... 64 第三部分 课程设计实验 .............................................................................................. 69
实验1 航空客运订票系统 ..................................................................................... 69 实验2 汉诺塔游戏程序......................................................................................... 75 实验3 全屏幕编辑程序设计 .................................................................................. 79 实验4 旅游路线安排模拟系统 .............................................................................. 90 实验6 最小生成树kruskal算法 ............................................................................. 93
i
第一部分 预备知识
预备知识
例1.1
#include
int sumabc(int a, int b, int c) /* 求三个整数之和*/
{ int s;
a=b+c;
s=a+b+c; return s;
}
void displayLine(void) { printf(”----------------------\\n“); }
void main( )
{ int x,y, z ,sabc;
x=y=z=8;
display(); /* 画一条线 */
printf(“\\n sum=%d”,sumabc(x,y,z)); /* 在输出语句中直接调用函数sumabc( ) */ printf(“\\n mmm”,x,y,z); display();/* 画一条线 */
x=2; y=4; z=6;
sabc =sumabc(x, y, z); /* 在赋值语句中调用函数sumabc( ) */ printf(“\\n “ sum=%d”, sabc);
printf(“\\n mmm”,x,y,z); display();/* 画一条线 */ }
例1.2
int sumabc(int *a, int b, int c) {
int s; *a=b+c;
s=*a+b+c;
1
return s;
}
预备知识实验
int main()
{ //在main函数中调用上述声明的函数 int n; //记录个数
STUDENT stu[MAXSIZE;// 顺序存储结构,方法一 静态一维数组。 /*
顺序存储结构,方法二 动态一维数组,用malloc函数分配如下: STUDENT *stu;
stu=( STUDENT *) malloc(sizeof(STUDENT)* MAXSIZE);// 内存空间的分配 注意:分配空间可用malloc()函数, 释放空间用free()函数,如free(stu); */
int index;
printf(\请输入学生记录个数n=\ scanf(%d”,&n); InputStu(stu, n); // 预先处理输入, 建表
while(1) // 永真循环,重复显示菜单, 直至退出
{
printf(\学生信息管理主菜单**********************\\n\ printf(\显示学生信息\\n\ printf(\查找学生信息\\n\ printf(\修改学生信息\\n\ printf(\添加学生信息\\n\ printf(\退出\\n\\n\);
printf(\请选择(1~5): \
scanf(\%d\
printf(\ switch(index) {
case 1: OutputStu(stu,n); break; case 2: SearchStu(stu,n); break;
case 3: UpdateStu (stu,n); break; case 4: AppendStu (stu,&n); break; case 5: return 0; default: printf(\输入有误,请重新输入! \\n\); }//switch
2
}//while(1) }//main
3