VC++基于链表的简易学生管理系统(小白)(一)

几年之前学的C,现在重新学一学,基本从零开始,主要目标做一个基于链表的简易学生管理系统。完全为初学者,请各位批评指正。此次主要是学习极客学院的视频。

首先,因为太久没有用过C了,先写了一个小程序重温重温,下面为当时写的程序:

#include <stdio.h>
void sleep(int a);


void main()
{
while(1)
{
printf("hello world");
sleep(1000);
}
}


void sleep(int a)
{
int i;
int j;
for(j=0;j<a*100;j++)
{
for(i=0;i<2000;i++);
}

}

想要延时1ms,但具体空循环的数值有点不记得了,所以时间比较随缘,不过还是能成功运行的。


熟悉之后,正式开始啦。

先学习主函数的设计。


1.先是malloc()函数,注意这个函数在stdlib.h,而不是在一般用的stdio.h中。

功能:

    在内存中分配size个字节存储空间,并返回指向被分配存储区起始地址的指针;如不能忽的需要的存储空间,返回空指针。

    注意:当把返回值赋给具有某一特定数据类型的指针变量时,应该对返回值做强制类型转换。

例如:为100个字符动态分配内存

char *ptr

ptr=(char*)malloc(100);//其中使用了强制转换,转换为字符型

例如:分配一个新的链表结点

l=(Node*)malloc(sizeof(Node));//sizeof用来计算Node占用的内存单元数

2.其次是calloc()函数,原型在头文件stdlib.h中定义

功能:

    分配n个具有size个字节的存储空间,并返回一个指向被分配内存起始地址的指针;如果没有足够的内存可供分配,则返回一个空指针。(相对于malloc()函数,这个可以分配多个

调用方式:void free(void *ptr)

3.再其次是free()函数,原型在头文件stdlib.h中定义

功能:

    释放由ptr指向的内存空间,并将它返回给堆。free函数无返回值。

    注意:ptr是最近一次调用malloc函数或calloc函数时返回的值。

            动态分配的存储单元在用完后一定要释放,否则内存会因为申请空间过多引起资源不足而故障。

调用方式:void free(void *ptr)

4.最后在主函数中调用menu_select()函数显示主功能菜单,并且在switch分支选择结构中调用各子函数实现对学生信息的插入、查询、显示、保存、删除以及加载等功能。

接着,下面为主程序函数:(从视频中摘抄的,最后会贴自己做的)

#include <stdio.h>
#include<stdlib.h>
#include<dos.h>
#include<string.h>
#include<conio.h>
#include<iostream>

int menu_select()
{
	int i;
	printf("\n\n\t ****************************STUDENT LIST****************************\n");
	printf("\t}*                       1.input record                 *|\n");
	printf("\t}*                       2.delete record                *|\n");
	printf("\t}*                       3.list record                  *|\n");
	printf("\t}*                       4.search record                *|\n");
	printf("\t}*                       5.save record                  *|\n");
	printf("\t}*                       6.load record                  *|\n");
	printf("\t}*                       7.quit                         *|\n");
	printf("\n\n\t ********************************************************************\n");
	do
	{
		printf("\n\tEnter your choice:");
		scanf("%d",&i);//扫描函数,将扫描的值存入i中
	}while(i<=0||i>7);//判断i值是否在1~7之间,否则继续要求输入
	return i;
}

void main()
{
	link l;
	l=(Node*)malloc(sizeof(Node));
	if(l!)
	{
		printf("\n allocate memory failure!");
		return;
	}
	l->next=NULL;
	while(1)
	{
		system("cls");
		swtich(menu_select())
		{
			case 1:
				input(l);
				break;
			case 2:
				del(l);
				break;
			case 3:
				list(l);
				break;
			case 4:
				search(l);
				break;
			case 5:
				save(l);
				break;
			case 6:
				load(l);
				break;
			case 7:
				exit(0);
		}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
学生管理系统(★★★) 使用下面的数据,用C设计一个简单的学籍管理系统,实现出最基本的功能。 学生基本信息文件(A.TXT)由以下内容: 学号 姓名 性别 宿舍号码 电话号码 01 张成成 男 501 87732111 02 李成华 女 101 87723112 03 王成凤 女 101 87723112 04 张明明 男 502 87734333 05 陈东 男 501 87732111 06 李果 男 502 87734333 07 张园园 女 102 87756122 … …. .. … ……….. 学生成绩基本信息文件(B.TXT)有以下内容: 学号 课程编号 课程名称 学分 平时成绩 实验成绩 卷面成绩 综合成绩 实得学分 01 A01 大学物理 3 66 78 82 02 B03 高等数学 4 78 -1 90 01 B03 高等数学 4 45 -1 88 02 C01 VF 3 65 76 66 … …. ………. .. .. … 功能要求及说明: (1)数据录入及插入功能: 对A..TXT和B.TXT进行数据录入,只录入每个学生的学号、课程编号、课程名称、学分、平时成绩、实验成绩、卷面成绩共7个数据. 综合成绩、学分由程序根据条件自动运算。并且最后也可插入学生数据。 综合成绩的计算:如果本课程的实验成绩为-1,则表示无实验,综合成绩=平时成绩*30%+卷面成绩*70%; 如果实验成绩不为-1,表示本课程有实验,综合成绩=平时成绩*15%+实验成绩*.15%+卷面成绩*70% . 实得学分的计算: 采用等级学分制. 综合成绩在90-100之间 ,应得学分=学分*100% 综合成绩在80-90之间 ,应得学分=学分*80% 综合成绩在70-80之间 ,应得学分=学分*75% 综合成绩在60-70之间 ,应得学分=学分*60% 综合成绩在60以下 ,应得学分=学分*0% (2)显示功能:要求可显示原A、B文件中的内容,并且插入信息后还可显示新内容。 (3)删除功能:当在A.TXT中删除一个学生时,自动地在B.TXT中删除此人所有信息,并显示输出结果。 (4) 排序功能:能实现选择按综合成绩或实得学分升序或降序排序并显示数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值