c 源码(c源码保存后会备份么)

本篇文章给大家谈谈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 源码到此分享完毕,希望能帮助到您。

© 版权声明
THE END
喜欢就支持一下吧
点赞12 分享