本篇文章给大家谈谈c 源码,以及c源码保存后会备份么对应的知识点,文章可能有点长,但是希望大家可以阅读完,增长自己的知识,最重要的是希望对各位有所帮助,可以解决了您的问题,不要忘了收藏本站喔。
在计算机科学的世界里,C语言源码就像是一座古老而神秘的城堡,它见证了编程的起源,承载着无数程序员的智慧和汗水。今天,就让我们一起来揭开这座城堡的神秘面纱,深入浅出地了解C语言源码,解锁编程世界的大门。
一、C语言源码的起源与发展
1. C语言的诞生
C语言诞生于1972年,由美国贝尔实验室的Dennis Ritchie设计。它是一种高级编程语言,具有强大的功能和灵活性,被誉为“计算机语言的基石”。
2. C语言的发展
自诞生以来,C语言经历了多次迭代和改进。从最初的C语言,到后来的C++、C等语言,都受到了C语言的影响。如今,C语言已经成为世界上最流行的编程语言之一。
二、C语言源码的结构
C语言源码主要由以下几部分组成:
| 序号 | 部分 | 说明 |
|---|---|---|
| 1 | 预处理指令 | 用于处理源代码中的预编译指令,如include、define等。 |
| 2 | 全局声明 | 声明全局变量、函数等,供整个程序使用。 |
| 3 | 函数定义 | 定义程序中的函数,实现特定功能。 |
| 4 | 主函数 | 程序的入口点,负责调用其他函数,控制程序流程。 |
| 5 | 局部声明 | 声明局部变量、函数等,仅在本函数内部有效。 |
| 6 | 注释 | 对源代码进行解释和说明,提高代码可读性。 |
三、C语言源码的编写技巧
1. 规范命名
在编写C语言源码时,应遵循规范命名规则,如使用驼峰命名法、下划线分隔等,使代码易于阅读和理解。
2. 注释说明
在代码中添加注释,对函数、变量等进行说明,有助于提高代码可读性。
3. 代码复用
通过函数封装、模块化设计等手段,提高代码复用率,降低代码冗余。
4. 优化性能
针对程序中的热点代码,进行性能优化,提高程序运行效率。
四、C语言源码的应用场景
C语言源码广泛应用于以下场景:
| 序号 | 应用场景 | 说明 |
|---|---|---|
| 1 | 操作系统 | 如Linux、Windows等,C语言源码是其核心部分。 |
| 2 | 嵌入式系统 | 如智能家居、物联网设备等,C语言源码用于实现底层功能。 |
| 3 | 游戏开发 | 如Unity引擎、UnrealEngine等,C语言源码用于实现游戏逻辑。 |
| 4 | 数据库 | 如MySQL、Oracle等,C语言源码用于实现数据库管理系统。 |
| 5 | 驱动开发 | 如显卡驱动、网卡驱动等,C语言源码用于实现硬件设备的驱动程序。 |
五、总结
C语言源码是编程世界的一把钥匙,它让我们能够深入理解计算机的工作原理,掌握编程技巧。通过学习C语言源码,我们可以更好地驾驭编程世界,创造出更多优秀的软件作品。
在今后的学习和工作中,让我们不忘初心,砥砺前行,用C语言源码解锁编程世界的大门,书写属于自己的精彩篇章!
C语言源代码是什么
数字版“拼图”游戏C源代码:
#include<time.h>
#include<stdio.h>
#include<stdlib.h>
#include<conio.h>
#include<windows.h>
int i, j, r, k;//i、j、r用于循环, k存放随机数值
int m, n;// m、n是当前空位的下标, t标记排序是否成功
int a[4][4];//存储4×4共16个数字的数组
void show(void);//输出数组表格
void csh(void);//初始化界面
int yes(void);//判断排序是否成功
void up(void);//数字向上移动到空位(空位则下移)
void down(void);//数字向下移
void left(void);//数字向左移
void rght(void);//数字向右移
void inkey(void);//按键操作
void gtxy(int x, int y);//控制光标移动的函数
int main(void)
{ while(1)
{csh();
while(1)
{ inkey();
show();
if( yes())
{gtxy(6,12); printf(“你成功了!再来一局y/n?”); break;}
}
if(getch()==ʹnʹ)break;
}
return 0;
}
void csh(void)
{r=0;
CONSOLE_CURSOR_INFO cursor_info={1,0};//以下两行是隐藏光标的设置
SetConsoleCursorInfo(GetStdHandle(STD_OUTPUT_HANDLE),&cursor_info);
for(i=0;i<4;i++)//给数组a依序赋值
for(j=0;j<4;j++)
{ if(i==3&& j==3) a[i][j]=0;
else a[i][j]=1+r++;
}
a[3][3]=a[1][1]; a[1][1]=0;//把a[3][3]与a[1][1]的值交换一下
m=1; n=1;
srand((unsigned)time(0));//初始化随机数发生器
for(r=0;r<500;r++)//将数组各值打乱
{k=rand()%(4);//取0-3随机数,分别代表上下左右四个方向
switch(k)
{ case 0:{ up();break;}
case 1:{down();break;}
case 2:{left();break;}
case 3:{rght(); break;}
}
}
printf(“
\t\t数字拼图”);
printf(“
\t┌──────┬──────┬──────┬──────┐”);
printf(“
\t│││││”);
printf(“
\t├──────┼──────┼──────┼──────┤”);
printf(“
\t│││││”);
printf(“
\t├──────┼──────┼──────┼──────┤”);
printf(“
\t│││││”);
printf(“
\t├──────┼──────┼──────┼──────┤”);
printf(“
\t│││││”);
printf(“
\t└──────┴──────┴──────┴──────┘”);
show();
}
void show(void)
{for(i=0;i<4;i++)
for(j=0;j<4;j++)//gtxy(7*j+9, 2*i+4)是光标到指定位置输出数字
{gtxy(7*j+9,2*i+4); if(a[i][j]==0)printf(“│”);
else if(a[i][j]>9)printf(“%d│”,a[i][j]);
else printf(“%d│”,a[i][j]);
}
}
void inkey(void)
{ int key;
key=getch();
switch(key)
{ case 72:{ up(); break;}
case 80:{down(); break;}
case 75:{left(); break;}
case 77:{rght();break;}
}
}
void up(void)
{ if(m!=3)//移动时要考虑空位”0″是否已经在边界
{ a[m][n]=a[m+1][n]; m++; a[m][n]=0;}
}
void down(void)
{ if(m!=0)
{a[m][n]=a[m-1][n]; m–; a[m][n]=0;}
}
void left(void)
{ if(n!=3)
{ a[m][n]=a[m][n+1]; n++; a[m][n]=0;}
}
void rght(void)
{ if(n!=0)
{ a[m][n]=a[m][n-1]; n–; a[m][n]=0;}
}
int yes(void)
{ r=0;
for(i=0;i<4;i++)
for(j=0;j<4;j++)
{ if(a[i][j]!=1+r++) return(r==16)?1:0;}
}
void gtxy(int x, int y)//控制光标移动的函数
{ COORD coord;
coord.X= x;
coord.Y= y;
SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE), coord);
}
c语言学生管理系统源代码
头文件:::
#ifndef H_STUDENT_HH
#define H_STUDENT_HH
#include”stdio.h”
#include”string.h”
#include”malloc.h”
#define LEN sizeof(struct message_student)/*一个结构体数组元素的长度*/
#define numsubs 5/*学科数目*/
typedef struct message_student/*结构体定义*/
{
char number[6];
char name[20];
char sex[4];
float subject[numsubs];
float score;
float average;
int index;
}student;
extern int numstus;/*学生数目*/
extern student*pointer;/*指向结构体数组*/
extern int lens;
int menu_select();/*函数声明*/
int openfile(student stu[]);
int findrecord(student stud[]);
int writetotext(student stud[]);
void welcome();
void display1();
void showtable();
void sort(student stu[]);
void deleterecord(student stu[],int i);
void addrecord(student stud[]);
void display(student stud[],int n1,int n2);
void amendrecord(student stud[]);
void count(student stud[]);
void sortnum(student stud[]);
void sortnum2(student stud[]);
void sortname(student stud[]);
void sortname2(student stud[]);
void sortcount(student stud[]);
void sortcount2(student stud[]);
void statistic(student stud[]);
void display1();
#endif
#include”head.h”
int menu_select()
{
char c;
printf(“\n\n”);
printf(“| 1.增加学生记录5.统计信息|\n”);
printf(“| 2.查询学生记录6.打开文件|\n”);
printf(“| 3.修改学生记录7.保存文件|\n”);
printf(“| 4.学生纪录排序8.显示记录|\n”);
printf(“|0.退出系统|\n”);
printf(“\n\n”);
printf(“请选择(0-8):”);
c=getchar();
getchar();
return(c-'0');
}
#include”head.h”
int findrecord(student stud[])/*查找信息*/
{
char str[2];
int i,num;
if(numstus==0)
{
printf(“没有可被查找的记录\n”);
return-1;
}
else
{
printf(“以何种方式查找?\n1.学号\t2.姓名\t3.名次\n”);
gets(str);
if(str[0]=='1')/*按学号查找*/
{
printf(“请输入学号:”);
gets(str);
for(i=0;i<=numstus;i++)
if(strcmp(str,stud[i].number)==0)
{
display(stud,i,i);
break;
}
else continue;
}
else if(str[0]=='2')/*按姓名查找*/
{
printf(“请输入姓名:”);
gets(str);
for(i=0;i<=numstus;i++)
if(strcmp(str,stud[i].name)==0)
{
display(stud,i,i);
break;
}
else continue;
}
else if(str[0]=='3')/*按名次查找*/
{
printf(“请输入名次:”);
scanf(“%d”,&num);
getchar();
for(i=0;i<=numstus;i++)
if(num==stud[i].index)
{
display(stud,i,i);
break;
}
else continue;
}
if(i>numstus)
{
printf(“没有查找所要的信息。\n”);
return-1;
}
return i;
}
}
#include”head.h”
int openfile(student stu[])
{
int i=0,j;
FILE*fp;
char filename[20],str[2];
if(numstus!=0)
{
printf(“已经有记录存在,是否保存?(y/n)”);
gets(str);
if(str[0]=='y'||str[0]=='Y')
writetotext(stu);
}
printf(“请输入文件名:”);
gets(filename);
numstus=0;
if((fp=fopen(filename,”rb+”))==NULL)
{
printf(“无法打开该文件\n”);
return(-1);
}
fscanf(fp,”%d”,&numstus);
fgetc(fp);
while(i<numstus)
{
fscanf(fp,”%s”,stu[i].number);
fscanf(fp,”%s”,stu[i].name);
fscanf(fp,”%s”,stu[i].sex);
for(j=0;j<numsubs;j++)
fscanf(fp,”%f”,&stu[i].subject[j]);
fscanf(fp,”%f”,&stu[i].score);
fscanf(fp,”%f”,&stu[i].average);
fscanf(fp,”%d”,&stu[i].index);
i++;
}
fclose(fp);
printf(“文件读取成功\n”);
printf(“是否显示纪录?(y/n)”);
gets(str);
if(str[0]=='y'||str[0]=='Y')
display(stu,0,numstus-1);
return(0);
}
#include”head.h”
void sort(student stud[])
{
int i,j=0;
char str[5];
student*p;
p=stud;
if(numstus==0)
{
printf(“没有可供查询的记录!”);
}
while(1)
{
for(i=0;;i++)
{
printf(“请输入查询方式:”);
printf(“(直接输入回车则结束查询操作)\n”);
printf(“1.按照学号\t”);
printf(“2.按照姓名\t”);
printf(“3.按照名次\n”);
gets(str);
if(strlen(str)==0) break;
if(str[0]=='1')
{
printf(“请输入排序次序:\n”);
printf(“1.升序排列\t”);
printf(“2.降序排列\n”);
gets(str);
if(str[0]=='1')
sortnum2(p);
else
sortnum(p);
display(stud,0,numstus-1);
}
else if(str[0]=='2')
{
printf(“请输入排序次序:\n”);
printf(“1.升序排列\t”);
printf(“2.降序排列\n”);
gets(str);
if(str[0]=='1')
sortname2(p);
else
sortname(p);
display(stud,0,numstus-1);
}
else if(str[0]=='3')
{
printf(“请输入排序次序:\n”);
printf(“1.升序排列\t”);
printf(“2.降序排列\n”);
gets(str);
if(str[0]=='1')
sortcount2(p);
else
sortcount(p);
display(stud,0,numstus-1);
}
else printf(“请输入1~3”);
printf(“是否退出排序?(y/n)”);
gets(str);
if(str[0]=='y'||str[0]=='Y') break;
}
return;
}
}
void sortnum(student stud[])
{
int i,j;
student temp;
student*p;
p=stud;
for(i=0;i<numstus;i++)
for(j=0;j<numstus-i-1;j++)
{
if(strcmp(stud[j+1].number,stud[j].number)>0)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
void sortnum2(student stud[])
{
int i,j;
student temp;
student*p;
p=stud;
for(i=0;i<numstus;i++)
for(j=0;j<numstus-i-1;j++)
{
if(strcmp(stud[j].number,stud[j+1].number)>0)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
void sortname(student stud[])
{
int i,j;
student temp;
student*p;
p=stud;
for(i=0;i<numstus;i++)
for(j=0;j<numstus-i-1;j++)
{
if(strcmp(stud[j+1].name,stud[j].name)>0)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
void sortname2(student stud[])
{
int i,j;
student temp;
student*p;
p=stud;
for(i=0;i<numstus;i++)
for(j=0;j<numstus-i-1;j++)
{
if(strcmp(stud[j].name,stud[j+1].name)>0)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
void sortcount(student stud[])
{
int i,j;
student temp;
student*p;
p=stud;
for(i=0;i<numstus;i++)
for(j=0;j<numstus-i-1;j++)
{
if(stud[j+1].index>stud[j].index)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
void sortcount2(student stud[])
{
int i,j;
student temp;
student*p;
p=stud;
for(i=0;i<numstus;i++)
for(j=0;j<numstus-i-1;j++)
{
if(stud[j].index>stud[j+1].index)
{
temp=*(p+j);
*(p+j)=*(p+j+1);
*(p+j+1)=temp;
}
}
}
#include”head.h”
void statistic(student stud[])/*新增功能,输出统计信息*/
{
int i,j=0,k=0;
char c1,str[2];
float average[numsubs],sum=0;
if(numstus==0)
printf(“没有可被查找的记录\n”);
else
{
while(1)
{
printf(“下面将统计考试成绩\n”);
printf(“请选择你要统计哪科的成绩1.A\t2.B\t3.C\t4.D\t5.E\n”);
c1=getchar();
printf(“\t一共有个%d记录\n”,numstus);/*总共记录数*/
switch(c1)
{
case'1':
for(i=0;i<numstus;i++)/*循环输入判断*/
{
sum+=stud[i].subject[0];
if(stud[k].subject[0]>stud[i].subject[0]) k=i;
if(stud[j].subject[0]<stud[i].subject[0]) j=i;
}
average[0]=sum/numstus;
printf(“\t科目A的最高分:\n”);/*最高分*/
printf(“\t\t学号:%s姓名:%s分数:%.2f\n”,stud[j].number,stud[j].name,stud[j].subject[0]);
printf(“\t科目A的最低分是:\n”);/*最低分*/
printf(“\t\t学号:%s姓名:%s分数:%.2f\n”,stud[k].number,stud[k].name,stud[k].subject[0]);
printf(“\t科目A的平均分是%5.2f\n”,average[0]);/*平均分*/
break;
case'2':
for(i=0;i<numstus;i++)/*循环输入判断*/
{
sum+=stud[i].subject[1];
if(stud[k].subject[1]>stud[i].subject[1]) k=i;
if(stud[j].subject[1]<stud[i].subject[1]) j=i;
}
average[1]=sum/numstus;
printf(“\t科目B的最高分:\n”);/*最高分*/
printf(“\t\t学号:%s姓名:%s分数:%.2f\n”,stud[j].number,stud[j].name,stud[j].subject[1]);
printf(“\t科目B的最低分是:\n”);/*最低分*/
printf(“\t\t学号:%s姓名:%s分数:%.2f\n”,stud[k].number,stud[k].name,stud[k].subject[1]);
printf(“\t科目B的平均分是%5.2f\n”,average[1]);/*平均分*/
break;
case'3':
for(i=0;i<numstus;i++)/*循环输入判断*/
{
sum+=stud[i].subject[2];
if(stud[k].subject[2]>stud[i].subject[2]) k=i;
if(stud[j].subject[2]<stud[i].subject[2]) j=i;
}
average[2]=sum/numstus;
printf(“\t科目C的最高分:\n”);/*最高分*/
printf(“\t\t学号:%s姓名:%s分数:%.2f\n”,stud[j].number,stud[j].name,stud[j].subject[2]);
printf(“\t科目C的最低分是:\n”);/*最低分*/
printf(“\t\t学号:%s姓名:%s分数:%.2f\n”,stud[k].number,stud[k].name,stud[k].subject[2]);
printf(“\t科目C的平均分是%5.2f\n”,average[2]);/*平均分*/
break;
case'4':
for(i=0;i<numstus;i++)/*循环输入判断*/
{
sum+=stud[i].subject[3];
if(stud[k].subject[3]>stud[i].subject[3]) k=i;
if(stud[j].subject[3]<stud[i].subject[3]) j=i;
}
average[3]=sum/numstus;
printf(“\t科目D的最高分:\n”);/*最高分*/
printf(“\t\t学号:%s姓名:%s分数:%.2f\n”,stud[j].number,stud[j].name,stud[j].subject[3]);
printf(“\t科目D的最低分是:\n”);/*最低分*/
printf(“\t\t学号:%s姓名:%s分数:%.2f\n”,stud[k].number,stud[k].name,stud[k].subject[3]);
printf(“\t科目D的平均分是%5.2f\n”,average[3]);/*平均分*/
break;
case'5':
for(i=0;i<numstus;i++)/*循环输入判断*/
{
sum+=stud[i].subject[4];
if(stud[k].subject[4]>stud[i].subject[4]) k=i;
if(stud[j].subject[4]<stud[i].subject[4]) j=i;
}
average[4]=sum/numstus;
printf(“\t科目E的最高分:\n”);/*最高分*/
printf(“\t\t学号:%s姓名:%s分数:%.2f\n”,stud[j].number,stud[j].name,stud[j].subject[4]);
printf(“\t科目E的最低分是:\n”);/*最低分*/
printf(“\t\t学号:%s姓名:%s分数:%.2f\n”,stud[k].number,stud[k].name,stud[k].subject[4]);
printf(“\t科目E的平均分是%5.2f\n”,average[4]);/*平均分*/
break;
default:printf(“输入错误!请输入1~5之间的数\n”);
}
sum=0;
getchar();
printf(“是否继续进行统计?(y/n)”);
gets(str);
if(str[0]=='y'||str[0]=='Y');
else break;
}
}
}
#include”head.h”
int writetotext(student stud[])/*将所有记录写入文件*/
{
int i=0,j;
FILE*fp;
char filename[20];
printf(“输入文件名称:”);
gets(filename);
fp=fopen(filename,”w”);
fprintf(fp,”%d\n”,numstus);
while(i<numstus)
{
fprintf(fp,”%s%s%s”,stud[i].number,stud[i].name,stud[i].sex);
for(j=0;j<numsubs;j++)
fprintf(fp,”%f”,stud[i].subject[j]);
fprintf(fp,”%f%f%d”,stud[i].score,stud[i].average,stud[i].index);
i++;
}
fclose(fp);
printf(“已成功存储!\n”);
display(stud,0,numstus-1);
numstus=0;
return 0;
}
#include”head.h”
void welcome()
{
printf(“\t*************************************************************\n”);
printf(“\t\t\t\t这是一个学生成绩管理系统\n\t\t\t\t倾情奉献欢迎使用!\n”);
printf(“\t*************************************************************\n”);
}
void showtable()
{
printf(“—————————————————————————————\n”);
printf(“学号\t姓名\t性别\tA\tB\tC\tD\tE\t总分\t平均分\t名次\n”);
printf(“—————————————————————————————\n”);
}
void display(student stud[],int n1,int n2)
{
int i;
showtable();/*显示表头*/
for(i=n1;i<=n2;i++)
printf(“%s\t%s\t%s\t%.2f\t%.2f\t%.2f\t%.2f\t%.2f\t%.2f\t%.2f\t%d\t\n”,stud[i].number,stud[i].name,stud[i].sex,stud[i].subject[0],stud[i].subject[1],stud[i].subject[2],stud[i].subject[3],stud[i].subject[4],stud[i].score,stud[i].average,stud[i].index);
/*通过循环输出数据*/
}
void display1()
{
printf(“\t\t本系统由计应精英一组亲情制作\n\n”);
printf(“\t\t制作人员列表:(按比划)\n”);
printf(“\t\t王庆斌\t\t\t张威\n\t\t李智\t\t\t周在峰\n\t\t杨凯\t\t\t胡杨\n”);
printf(“\n\n”);
getchar();
}
#include”head.h”
#include<string.h>
void amendrecord(student stud[])
{
char str[5];/*供用户输入*/
int i=-1,j;
if(numstus==0)/*没有记录返回*/
printf(“没有可供修改的记录!”);
while(i<0)
{
i=findrecord(stud);
if(i>=0)
{
printf(“要删除这个学生的信息吗?(y/n)”);
gets(str);
if(str[0]=='y'||str[0]=='Y')
{
deleterecord(stud,i);
count(stud);
}
else
{
printf(“确定要修改这个学生的信息吗?(y/n)”);
gets(str);
if(str[0]=='y'||str[0]=='Y')
{
printf(“下面请重新输入学生的信息:\n”);
printf(“请输入学号:”);
gets(stud[i].number);
printf(“请输入姓名:”);
gets(stud[i].name);
printf(“请输入性别(男/女1/0):”);
gets(str);
if(str[0]=='0')
strcpy(stud[i].sex,”女”);
else
strcpy(stud[i].sex,”男”);
stud[i].score=0;
printf(“请按顺序输入成绩:”);
for(j=0;j<numsubs;j++)
{
scanf(“%f”,&stud[i].subject[j]);
stud[i].score+=stud[i].subject[j];
}
getchar();
stud[i].average=stud[i].score/numsubs;
}
count(stud);
}
display(stud,0,numstus-1);
}
printf(“是否继续进行其他修改?(y/n)\n”);
gets(str);
if(str[0]=='y'||str[0]=='Y')
i=-1;
else i=1;
}
}
void deleterecord(student stu[],int i)/*删除信息*/
{
int j;
while(i>=0)
{
for(j=i;j<numstus;j++)
stu[j]=stu[j+1];
numstus–;
printf(“删除成功!\n”);
}
}
void count(student stud[])
{
int i,j;
for(i=0;i<numstus;i++)
{
stud[i].index=1;
for(j=0;j<numstus;j++)
if(stud[j].score>stud[i].score)
stud[i].index++;
}
}
#include”head.h”
void addrecord(student stud[])
{
int i=0,j,num;
char str[5];
if(numstus!=0)
{
printf(“已有记录存在是否覆盖?(y/n)\n”);
gets(str);
if(str[0]=='Y'||str[0]=='y')
i=0;
else i=numstus;
}
printf(“请输入增加的学生信息条目数:”);
scanf(“%d”,&num);
if(i==0)
numstus=num;
else numstus+=num;
if(numstus>lens)
{
lens+=50;
pointer=(student*)realloc(pointer,lens*LEN);
}
printf(“请输入学生信息:\n”);
for(;i<numstus;i++)
{
getchar();
printf(“请输入学号:”);
gets(pointer[i].number);
printf(“请输入姓名:”);
gets(pointer[i].name);
printf(“请输入性别(男/女1/0):”);
gets(pointer[i].sex);
if(pointer[i].sex[0]=='0') strcpy(pointer[i].sex,”女”);
else strcpy(pointer[i].sex,”男”);
printf(“请输入各科成绩:(按ABCDE的顺序):”);
stud[i].score=0;
for(j=0;j<numsubs;j++)
{
scanf(“%f”,&stud[i].subject[j]);/*计算总分*/
stud[i].score+=stud[i].subject[j];
}
stud[i].average=stud[i].score/numsubs;/*计算平均分*/
}
count(stud);/*附名次*/
display(stud,0,numstus-1);
getchar();
}#include”head.h”
int numstus;
int lens;
student*pointer;
void main()
{
int i=1;
char str[2];
lens=100;
pointer=(student*)malloc(lens*LEN);/*分配内存*/
numstus=0;
welcome();/*欢迎界面*/
while(i>0)
{
i=menu_select();/*控制菜单*/
switch(i)
{
case 1:addrecord(pointer);break;/*增加学生信息*/
case 2:findrecord(pointer);break;/*查询学生信息*/
case 3:amendrecord(pointer);break;/*修改学生信息*/
case 4:sort(pointer);break;/*学生信息排序*/
case 5:statistic(pointer);break;/*统计信息*/
case 6:openfile(pointer);break;/*打开文件*/
case 7:writetotext(pointer);break;/*保存文件*/
case 8:display(pointer,0,numstus-1);break;/*显示记录*/
case 0:
if(numstus!=0) printf(“是否保存当前记录?(y/n)”);
gets(str);
if(str[0]=='y'||str[0]=='Y')
writetotext(pointer);
i=-1;break;/*退出系统*/
default:printf(“请输入数字0~8:\n”);i=1;/*输入错误*/
}
}
printf(“\t\t欢迎再次使用本系统。\n\n”);
display1();
}
自己一改就能用,给我加分哈!
打字不易,如满意,望采纳。
求C语言图书管理系统源代码
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
//
#define MAXSIZE 100//最大值定义为100
#define LIST_INIT_SIZE 100//图书证使用者最大值定义为100
//借书人的结构体
typedef struct Boro//借书行为
{
char BNum[20];//借书的书号
char RetDate[8];//归还日期
struct Boro*next;
}Bor;
typedef struct LinkBook
{
Bor*next;//该图书证的借书行为
char CNum[20];//证号
int Total;//借书的数量
}lend[LIST_INIT_SIZE];//借书人数组
//图书的结构体信息
typedef struct LNode
{
char CardNum[20];//图书证号
struct LNode*next;
}LinkList;//借书人
typedef struct book
{//每种图书需要登记的内容包括书号ISBN、书名、作者、出版社、总库存量和现库存量。
char num[20];//书号
char name[20];//书名
char auth[20];//作者
char pub[20];//出版社
int TotNum;//总库存
int NowNum;//现库存
LinkList*next;//借了该书的人
}ook[MAXSIZE];
//
int Retotal;//读者数量
int total;//定义外部变量.书的种类数
//
//结构体初始化
void InitBo(ook&boo)//初始化图书信息
{
for(int i=0;i<MAXSIZE;i++)
{
boo[i].NowNum=0;
boo[i].TotNum=0;
boo[i].next=NULL;
}
}
void InitRe(lend&Lin)//初始化借阅者信息
{
for(int i=0;i<LIST_INIT_SIZE;i++)
Lin[i].next=NULL;
}
//
int mid=0;//外部函数mid,用来返回查找到的位置
bool BinarySearch(ook boo,char SearchNum[])//二分法查找比较书号
{//用bool函数,但由于函数不能有两个返回值,所以设置一个外部变量mid,用来返回查找到的位置
int low=0,high=total-1;
int found=0;
while(low<=high)
{
mid=(low+high)/2;//中间点
if(strcmp(boo[mid].num,SearchNum)==0)//书号相同
{
found=1;
return true;
}//查找成功
if(strcmp(boo[mid].num,SearchNum)!=0)//书号不同
high=mid-1;
elselow=mid+1;
}
if(found==0)
return false;//查找失败
}
void Buy(ook&boo, char BuyNum[])
{//1、采编入库:新购入一种书,如果该书在图书账目中已经存在,则将其库存量增加(包
//括总库存量和现库存量),如果该书不存在,则在图书账目中增加一种书,总库存量和现库存量均为1。
if(BinarySearch(boo,BuyNum))//如果书库中有此书
{
boo[mid].TotNum++;//总库存加1
boo[mid].NowNum++;//现库存加1
printf(“入库成功.\n”);
printf(“已更改书库中该书的信息。编号%s的书%s作者是%s,出版社是%s,目前的总库存是%d,现库存是%d。\n”,boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].TotNum,boo[mid].NowNum);
}
if(!BinarySearch(boo,BuyNum))
{
int i;
for(i=total;i>mid&&total;i–)//插在适合位置保持有序
boo[i]=boo[i-1];//空出插入位置
printf(“该书在书库中不存在。设立新书目,请补全书的详细信息。\n”);
strcpy(boo[i].num,BuyNum);
printf(“该书购入的数量是:”);
scanf(“%d”,&boo[i].NowNum);
boo[i].TotNum=boo[i].NowNum;
printf(“该书的名字是:”);
scanf(“%s”,&boo[i].name);
printf(“该书的作者是:”);
scanf(“%s”,&boo[i].auth);
printf(“该书的出版社是:”);
scanf(“%s”,&boo[i].pub);//补全信息
boo[i].next=NULL;
total++;//总量+1
printf(“已增加该书的信息。编号%s的书%s作者是%s,出版社是%s,目前的总库存是%d,现库存是%d。\n”,boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum);
printf(“入库成功.\n”);
}
}
void Delete(ook&boo,char DeleteNum[])
{//2、清空库存:某一种书已无保留价值,将它从图书账目中注销。
if(BinarySearch(boo,DeleteNum)==false||total==0)//如果无此书
printf(“书库中没有该书.\n”);
if(BinarySearch(boo,DeleteNum))//若有
{
if(!boo[mid].next)
{
int j;
for( j=mid;j<total;j++)
boo[j]=boo[j+1];
strcpy(boo[j].num,boo[j+1].num);
strcpy(boo[j].name,boo[j+1].name);
strcpy(boo[j].auth,boo[j+1].auth);
strcpy(boo[j].pub,boo[j+1].pub);
boo[j].TotNum=boo[j+1].TotNum;
boo[j].NowNum=boo[j+1].NowNum;
printf(“已成功删除该书.\n”);
}
else printf(“该书有借阅者,无法删除。\n”);
}
}
void Borrow(ook&boo,lend&Lin,char BorrowNum[],char CaNum[])
{//3、借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1,
//并登记借阅者的图书证号和归还期限。
Bor*p,*q;
LinkList*m,*n;
if(!BinarySearch(boo,BorrowNum)||total==0)//如果没有找到此书
printf(“书库里没这书。\n”);//如果有这书
if(BinarySearch(boo,BorrowNum))//书库里有
{
if(boo[mid].NowNum>0)//看现库存是否大于0
{
boo[mid].NowNum–;//借出一本,少1
if(boo[mid].next==NULL)//若该书信息下显示该种书还没被人借过
{
m=(LinkList*)malloc(sizeof(LNode));//分配
boo[mid].next=m;//该图书信息中的链表的第一个结点
strcpy(m->CardNum,CaNum);
m->next=NULL;//后一个结点为空
}
else//如果已经有人在借这书了
{
m=boo[mid].next;
while(m->next)//遍历到最后一个结点
m=m->next;
n=(LinkList*)malloc(sizeof(LNode));//分配空间,增加1个结点
m->next=n;
strcpy(n->CardNum,CaNum);//记录证号
n->next=NULL;
}
int i=0;
for(i=0;i<Retotal;i++)//
{
if(!strcmp(Lin[i].CNum,CaNum))//如果已经有该图书证的信息
{
p=Lin[i].next;
while(p->next)p=p->next;//遍历到最后一个结点
q=(Bor*)malloc(sizeof(Boro));//分配空间
p->next=q;
strcpy(q->BNum,BorrowNum);//记录书号
printf(“输入归还日期:”);
scanf(“%s”,&q->RetDate);
q->next=NULL;
printf(“借阅成功.\n”);
break;//找到证了就跳出循环
}
}
if(i==Retotal)//如果没有这张证的信息
{
strcpy(Lin[i].CNum,CaNum);//记录证号
p=(Bor*)malloc(sizeof(Boro));//分配空间
Lin[i].next=p;
strcpy(p->BNum,BorrowNum);
printf(“输入归还日期:”);
scanf(“%s”,&p->RetDate);
p->next=NULL;
Retotal++;//借阅证号信息总数加1
printf(“借阅成功.\n”);
}
}
else printf(“借阅失败.该书现在库存为0.\n”);
}
}
void Return(ook&boo,lend&Lin,char ReturnNum[],char BorrowerNum[])
{//4、归还:注销对借阅者的登记,改变该书的现存量。
Bor*p,*q;
LinkList*m,*n;
int flag=0;//设置一个参数
if(!BinarySearch(boo,ReturnNum)||!total)//没书
printf(“书库中无此书.\n”);
if(BinarySearch(boo,ReturnNum))//有书
{
m=boo[mid].next;
if(!strcmp(m->CardNum,BorrowerNum))//如果是第一个借的人还的
{
boo[mid].NowNum++;//现库存加1
boo[mid].next=m->next;//删除结点
free(m);//释放该结点的空间空间
}
else
{
while(m->next)//查找归还者的借阅者结点
{
if(!strcmp(m->next->CardNum,BorrowerNum))//如果找到
{
n=m->next;//n为归还者的借阅结点
m->next=n->next;//m指向归还者的借阅结点的下一结点
free(n);//释放空间
boo[mid].NowNum++;//现库存加1
break;
}
m=m->next;
}
}
}
//在借阅者表里查找借阅者信息
for(int i=0;i<Retotal;i++)
{
if(!strcmp(Lin[i].CNum,BorrowerNum))//如果找到借阅者
{
p=Lin[i].next;
if(!strcmp(p->BNum,ReturnNum))//如果是归还的是借的第一本书
{
Lin[i].next=p->next;//指向下一借书结点
free(p);//释放结点空间
printf(“成功归还该书.\n”);
flag=1;
break;
}
else//找不到
{
while(p->next)//找到归还书的借书结点
{
if(!strcmp(p->next->BNum,ReturnNum))//如果找到
{
q=p->next;//q为归还书的借书结点
p->next=q->next;//p指向下一借书结点
free(q);//释放空间
printf(“成功归还该书.\n”);
flag=1;
break;
}
p=p->next;
}
}
}
}
for(int k=0;k<Retotal;k++)
if(!Lin[k].next)
{
int j;
for(j=k;j<Retotal;j++)
Lin[j]=Lin[j+1];//其后都往前移一位,覆盖掉当前信息
strcpy(Lin[j].CNum,””);//删除图书证号
Retotal–;//图书证数减1
}//删除当前状态下没借书的图书证的信息,节省空间
if(flag==0)printf(“无该证信息.\n”);
}
//5、查找:实现按三种查询条件之一查找:按书号查找、
//按书名查找、按作者查找。注:可不实现组合查找,即几个条件组合查找。
void SearchByNum(ook&boo,char SeaNum[])
{//BY NUM根据书号查找
LinkList*p;
p=boo[mid].next;
if(BinarySearch(boo,SeaNum)==false)printf(“对不起,未找到您想查找的书。\n”);//二分查找没找到
else//找到了的话
{
{
printf(“┏━━━━━━━┳━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━┳━━━━━┓\n”);
printf(“┃书号┃书名┃作者┃出版社┃现库存┃总库存┃\n”);
printf(“┣━━━━━━━╋━━━━━━━╋━━━━━━━━╋━━━━━━━━╋━━━━━╋━━━━━┫\n”);
printf(“┃%14s┃%14s┃%16s┃%16s┃%10d┃%10d┃\n”,boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].NowNum,boo[mid].TotNum);
printf(“┗━━━━━━━┻━━━━━━━┻━━━━━━━━┻━━━━━━━━┻━━━━━┻━━━━━┛\n”);
if(boo[mid].next!=NULL)
{
printf(“┏━━━━━━━┓\n”);
printf(“┃已借该书的┃\n”);
printf(“┃图书证号┃\n”);
while(p)
{
printf(“┣━━━━━━━┫\n”);
printf(“┃%14s┃\n”,p->CardNum);
p=p->next;
}
printf(“┗━━━━━━━┛\n”);
}
}
while(p)
{
printf(“%s”,p->CardNum);//在按书号查找的函数里也显示借了这本书的借阅者的证号
p=p->next;
}
printf(“\n”);
}//显示查找的书籍的信息
}
void SearchByName(ook&boo)
{//BY NAME根据书名查找
char SeaName[20];
printf(“输入想查找的书的书名:\n”);
scanf(“%s”,&SeaName);
printf(“找到符合该书名的书的详细信息如下:\n”);
for(int i=0;i<total;i++)
{
if(strcmp(SeaName,boo[i].name)==0)//如果书名一样
{
printf(“书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n”,boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum);
}//显示符合信息的所有书籍的信息
}
}
void SearchByAuth(ook&boo)
{// BY AUTH根据作者查找
char SeaAuth[20];
printf(“输入想查找的书的作者:\n”);
scanf(“%s”,&SeaAuth);
printf(“找到符合该作者的书的详细信息如下:\n”);
for(int i=0;i<total;i++)
{
if(strcmp(SeaAuth,boo[i].auth)==0)//如果作者一样
{
printf(“书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n”,boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum);
}//显示符合信息的所有书籍的信息
}
}
//6、查看:可查看某图书证号的借阅者借阅的全部图书,可查看全部超期未还的图书。
void ViewCard(ook&boo,lend&Lin)
{//查看某图书证号的借阅者借阅的全部图书
char Num[20];
printf(“请输入您所想要查看的图书证号:\n”);
scanf(“%s”,&Num);
Bor*p;
int qqq=0;
for(int i=0;i<Retotal;i++)
{
if(strcmp(Lin[i].CNum,Num)==0)//找到该证
{
printf(“这个证借的书有:\n”);
p=Lin[i].next;
while(p)
{
printf(“%s”,p->BNum);//书号
p=p->next;
}
printf(“\n”);
qqq=1;
break;
}
}
if(qqq==0)
printf(“该证不存在.\n”);
}
void ViewBook(ook&boo,lend&Lin)
{//查看全部超期未还的图书
char date[8];
Bor*p;
printf(“请输入日期(请按格式20060605输入):\n”);
scanf(“%s”,&date);
printf(“所有超期未还的书有:\n”);
for(int i=0;i<Retotal;i++)
{
p=Lin[i].next;
while(p)//当p不空时
{
if(strcmp(p->RetDate,date)<0)//超过日期
{
printf(“书号为%s证号为%s应归还日期为%s\n”,p->BNum,Lin[i].CNum,p->RetDate);
}//显示所有超期未还的书的信息
p=p->next;
}
}
}
void Menu()//菜单
{
printf(“┏—————————————————MENU————————————————┓\n”);
printf(“││\n”);
printf(“│1.采编入库:新购入一种书,如果该书在图书账目中已经存在,│\n”);
printf(“│则将其库存量增加(包括总库存量和现库存量)。│\n”);
printf(“│如果该书不存在,则在图书账目中增加一种书,│\n”);
printf(“│总库存量和现库存量均为输入的数字。│\n”);
printf(“│2.清空库存:某一种书已无保留价值,将它从图书账目中注销。│\n”);
printf(“│3.借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1,│\n”);
printf(“│并登记借阅者的图书证号和归还期限。│\n”);
printf(“│4.归还:注销对借阅者的登记,改变该书的现存量。│\n”);
printf(“│5.按书号查找。│\n”);
printf(“│6.按书名查找。│\n”);
printf(“│7.按作者查找。│\n”);
printf(“│8.查看某图书证号的借阅者借阅的全部图书。│\n”);
printf(“│9.查看全部超期未还的图书。│\n”);
printf(“│0.退出图书管理系统。│\n”);
printf(“││\n”);
printf(“┗—————————————请选择你需要的操作————————————┛\n”);
}
int main()
{
ook Bo;
lend Lin;
char BNum[20];
char CNum[20];
printf(“———————–欢迎进入图书管理系统!—————————\n\n”);
int choice=10;
int SearchCho=10,ViewCho=10;
while(choice!=0)
{
Menu();//显示菜单
scanf(“%d”,&choice);
switch(choice)
{
case 1://采编入库
printf(“请输入入库的书的书号:”);
scanf(“%s”,BNum);
Buy(Bo,BNum);
case 2://清空库存
printf(“请输入想要清除的书的书号:”);
scanf(“%s”,BNum);
Delete(Bo,BNum);
break;
case 3://借阅
printf(“请输入想要借阅的书的书号:\n”);
scanf(“%s”,&BNum);
printf(“请输入图书证号:”);
scanf(“%s”,&CNum);
Borrow(Bo,Lin,BNum,CNum);
break;
case 4://归还
printf(“请输入想要归还的书的书号:\n”);
scanf(“%s”,&BNum);
printf(“请输入图书证号:”);
scanf(“%s”,&CNum);
Return(Bo,Lin,BNum,CNum);
break;
case 5://查找//根据书号查找
printf(“请输入书号:”);//输入书号查找
scanf(“%s”,&BNum);
SearchByNum(Bo,BNum);
break;
case 6://根据书名查找
SearchByName(Bo);
break;
case 7://根据作者查找
SearchByAuth(Bo);
break;
case 8://查看某图书证所借的所有书
ViewCard(Bo,Lin);
break;
case 9://查看全部超期未还的书
ViewBook(Bo,Lin);
break;
case 0://退出系统
exit(0);break;
default:printf(“输入错误!\n”);exit(0);break;
}
}
关于c 源码到此分享完毕,希望能帮助到您。




