用C语言编写一个车票管理系统

用C语言编写一个车票管理系统,第1张

1、首先打开CodeBlocks,新建一个空白文件。先定义头文件和主函数。

2、定义所需要的变量,因为有除法,肯定会有小数出现,所以将变量定义为浮点型。

3、定义输入函数,将刚才的x和y定义为计算的变量,将c定义为选择计算方式的变量。scanf("%f%c%f",&x,&c,&y)。

4、添加switch函数,将c作为选择变量。

5、然后在主函数中输入一个输出函数来输出计算式及结果。

6、这时进行运行如图,计算正常。

#include <iostream>

#include <iomanip>

#include <string>

#include <fstream>//输入/输出文件流类

using namespace std;

const int Maxr=100;//最多的读者

const int Maxb=100;//最多的图书

const int Maxbor=5;//每位读者最多借五本书

//读者类,实现对读者的信息的描述

class Reader

{

private:

int tag; //删除标记 1:已删 0:未删

int no; //读者编号

char name[10]; //读者姓名

int borbook[Maxbor];//所借图书

public:

Reader() {}

char getname() //获取姓名

int gettag() //获取删除标记

int getno() //获取读者编号

void setname(char na[]) //设置姓名

{

strcpy(name,na);

}

void delbook()//设置删除标记 1:已删 0:未删

void addreader(int n,char na)//增加读者

{

tag=0;

no=n;

strcpy(name,na);

for(int i=0;i<Maxbor;i++)

borbook[i]=0;

}

void borrowbook(int bookid)//借书 *** 作

{

for(int i=0;i<Maxbor;i++)

{

if (borbook[i]==0)

{

borbook[i]=bookid;

return;

}

}

}

int retbook(int bookid)//还书 *** 作

{

for(int i=0;i<Maxbor;i++)

{

if(borbook[i]==bookid)

{

borbook[i]=0;

return 1;

}

}

return 0;

}

void disp()//读出读者信息

{

cout << setw(5) << no <<setw(10) << name<<"借书编号:[";

for(int i=0;i<Maxbor;i++)

if(borbook[i]!=0)

cout << borbook[i] << "|";

cout << "]"<<endl;

}

};

//读者类库,实现建立读者的个人资料

class RDatabase

{

private:

int top; //读者记录指针

Reader read[Maxr];//读者记录

public:

RDatabase() //构造函数,将readertxt读到read[]中

{

Reader s;

top=-1;

fstream file("readertxt",ios::in);//打开一个输入文件

while (1)

{

fileread((char )&s,sizeof(s));

if (!file)break;

top++;

read[top]=s;

}

fileclose(); //关闭 readertxt

}

void clear()//删除所有读者信息

{

top=-1;

}

int addreader(int n,char na)//添加读者时先查找是否存在

{

Reader p=query(n);

if (p==NULL)

{

top++;

read[top]addreader(n,na);

return 1;

}

return 0;

}

Reader query(int readerid)//按编号查找

{

for (int i=0;i<=top;i++)

if (read[i]getno()==readerid &&

read[i]gettag()==0)

{

return &read[i];

}

return NULL;

}

void disp() //输出所有读者信息

{

for (int i=0;i<=top;i++)

read[i]disp();

}

void readerdata();//读者库维护

~RDatabase() //析构函数,将read[]写到readertxt文件中

{

fstream file("readertxt",ios::out);

for (int i=0;i<=top;i++)

if (read[i]gettag()==0)

filewrite((char )&read[i],sizeof(read[i]));

fileclose();

}

};

void RDatabase::readerdata()

{

char choice;

char rname[20];

int readerid;

Reader r;

while (choice!='0')

{

cout <<"\n\n\t\t\t读 者 维 护\n\n\n\t\t 1 新 增\n\n\t\t 2 更 改\n\n\t\t 3 删 除\n\n\t\t 4 查 找\n\n\t\t 5 显 示\n\n\t\t 6 全 删\n\n\t\t 0 退 出"<<endl;

cin >> choice;

switch (choice)

{

case '1':

cout << "输入读者编号:";

cin >> readerid;

cout << "输入读者姓名:";

cin >> rname;

addreader (readerid,rname);

break;

case '2':

cout << "输入读者编号:";

cin >> readerid;

r=query(readerid);

if (r==NULL)

{

cout << " 该读者不存在 "<<endl;

break;

}

cout << "输入新的姓名:";

cin >> rname;

r->setname(rname);

break;

case '3':

cout << " 输入读者编号:";

cin >> readerid;

r=query(readerid);

if (r==NULL)

{

cout <<" 该读者不存在" << endl;

break;

}

r->delbook();

break;

case '4':

cout << "读入读者编号:";

cin >> readerid;

r=query(readerid);

if (r==NULL)

{

cout <<"该读者不存在"<< endl;

break;

}

r->disp();

break;

case '5':

disp();

break;

case '6':

clear();

break;

default:cout<<"输入错误,请从新输入:";break;

}

}

}

//图书类,实现对图书的描述,图书的编号,书名,借出,还入等

class Book

{

private:

int tag;//删除标记 1:已删 0:未删

int no;//图书编号

char name[20];//书名

int onshelf;//是否再架 1:再架 2:已借

public:

Book(){}

char getname() //获取姓名

int getno()//获取图书编号

int gettag()//获取删除标记

void setname(char na[])//设置书名

{

strcpy(name,na);

}

void delbook()//删除图书

void addbook(int n,char na)//增加图书

{

tag=0;

no=n;

strcpy(name,na);

onshelf=1;

}

int borrowbook()//借书 *** 作

{

if (onshelf==1)

{

onshelf=0;

return 1;

}

return 0;

}

void retbook()//还书 *** 作

{

onshelf=1;

}

void disp()//输出图书

{

cout << setw(6) << no << setw(18) << name << setw(10)

<<(onshelf==1 "在架":"已借") <<endl;

}

};

//图书库类,实现对图书的维护,查找,删除等

class BDatabase

{

private:

int top; //图书记录指针

Book book[Maxb]; //图书记录

public:

BDatabase()//构造函数,将booktxt读到book[]中

{

Book b;

top=-1;

fstream file("booktxt",ios::in);

while (1)

{

fileread((char )&b,sizeof(b));

if (!file) break;

top++;

book[top]=b;

}

fileclose();

}

void clear()//全删

{

top=-1;

}

int addbook(int n,char na)//增加图书

{

Book p=query(n);

if (NULL==p)

{

top++;

book[top]addbook(n,na);

return 1;

}

return 0;

}

Book query(int bookid)//查找图书

{

for (int i=0;i<=top;i++)

if (book[i]getno()==bookid &&book[i]gettag()==0)

{

return &book[i];

}

return NULL;

}

void bookdata();//图书库维护

void disp()

{

for (int i=0;i<=top;i++)

if (book[i]gettag()==0)

book[i]disp();

}

~BDatabase()//析构函数,将book[]写到booktxt文件中

{

fstream file("booktxt",ios::out);

for (int i=0;i<=top;i++)

if (book[i]gettag()==0)

filewrite((char )&book[i],sizeof(book[i]));

fileclose();

}

};

void BDatabase::bookdata()

{

char choice;

char bname[40];

int bookid;

Book b;

while (choice!='0')

{

cout <<"\n\n\n\t\t\t图 书 维 护 "<<endl<<endl;

cout<<"\t\t1 新 增\n \t\t2 更 改\n\t\t3 删 除\n\t\t4 查 找\n\t\t5 显 示\n\t\t6 全 删\n\t\t0 退 出"<<endl;

cin >> choice;

switch (choice)

{

case '1':

cout << "输入图书编号:"<<endl;

cin >> bookid;

cout << "输入图书书名:"<<endl;

cin >> bname;

addbook(bookid,bname);

break;

case '2':

cout << "输入图书编号:"<<endl;

cin >> bookid;

b=query(bookid);

if (b==NULL)

{

cout << " 该图书不存在 "<<endl;

break;

}

cout << "输入新的书名:"<<endl;

cin >> bname;

b->setname(bname);

break;

case '3':

cout <<" 读入图书编号:"<<endl;

cin >> bookid;

b=query(bookid);

if (b==NULL)

{

cout <<" 该图书不存在" << endl;

break;

}

b->delbook();

break;

case '4':

cout << " 读入图书编号:"<<endl;

cin >> bookid;

b=query(bookid);

if (b==NULL)

{

cout <<" 该图书不存在"<< endl;

break;

}

b->disp();

break;

case '5':

disp();

break;

case '6':

clear();

break;

default:cout<<"输入错误,请从新输入:";

}

}

}

//main() 函数的实现,程序的主界面的引导

void main()

{

char choice;

int bookid,readerid;

RDatabase ReaderDB;

Reader r;

BDatabase BookDB;

Book b;

while(choice!='0')

{

cout <<endl<<endl<<"\t\t\t 图 书 管 理 系 统\n\n\n";

cout <<"\t\t\t1 借 书\n\n\t\t\t2 还 书 \n\n\t\t\t3 图 书 维 护\n\n\t\t\t4 读 者 维 护\n\n\t\t\t0 离 开"<<endl;

cin >> choice;

switch (choice)

{

case '1':

cout <<" 借书 读者编号:";

cin >>readerid;

cout <<" 图书编号: ";

cin >>bookid;

r=ReaderDBquery(readerid);//按编号查找

if (NULL==r)

{

cout <<" 不存在该读者,不能借书"<< endl;

break;

}

b=BookDBquery(bookid);

if (b==NULL)

{

cout <<" 不存在该图书,不能借书"<< endl;

break;

}

if (b->borrowbook()==0)

{

cout << " 该图书已借出,不能借书"<< endl;

break;

}

r->borrowbook(b->getno());

break;

case '2':

cout<<"还书\n 读者编号:";

cin >>readerid;

cout << " 图书编号:";

cin >>bookid;

r=ReaderDBquery(readerid);

if (r==NULL)

{

cout <<" 不存在该读者,不能还书" << endl;

break;

}

b=BookDBquery(bookid);

if (b==NULL)

{

cout <<" 不存在该图书,不能还书" <<endl;

break;

}

b->retbook();

r->retbook(b->getno());

break;

case '3':

BookDBbookdata();

break;

case '4':

ReaderDBreaderdata();

break;

default:cout<<"输入错误,请从新输入:";

}

}

}

/

创建日期:2011-04-27

程序名称:链表综合 *** 作

程序作者:子夜星空

备注信息:以前写的。

/

#include <stdioh>

#include <stringh>

#include <stdlibh>

#define SN 2 //科目数

typedef struct student

{

char num[10],

name[10];

float score[SN],

sum,

avg;

struct student next;

}STU;

/输入链表单元内容/

void input(STU p)

{

int i;

printf("please input number:\n");

scanf("%s",p->num);

printf("please input name:\n");

scanf("%s",p->name);

printf("please input %d scores:\n",SN);

p->sum=0;

for(i=0;i<SN;i++)

{

scanf("%f",&p->score[i]);

p->sum+=p->score[i];

}

p->avg=p->sum/SN;

}

/创建一个链表单元/

STU creat_node()

{

STU p;

p=(STU )malloc(sizeof(STU));

if(p == NULL)

{ printf("No enough memory !");

exit(0);

}

input(p);

p->next=NULL;

return p;

}

/创建一个链表/

STU creat_list()

{

STU head=NULL,tail=NULL,p;

char str[4];

printf("List creating\n");

do

{

printf("Do you want to continue (yes/no) :");

scanf("%s",str);

if(strcmp(str,"yes")==0)

{

p=creat_node();

if(head==NULL){head=tail=p;continue;}

tail->next=p;

tail=p;

}

if(strcmp(str,"yes")!=0&&strcmp(str,"no")!=0)

{

printf("You must input 'yes' or 'no'\n");

//getchar();

continue;

}

if(strcmp(str,"no")==0)break;

//getchar();

}while(1);

printf("List create end\n\n");

return head;

}

/输出一个链表单元/

void print_a_node(STU fin)

{

int i;

printf("%s;\t%s;\t%02f;\t%02f\t",fin->num,fin->name,fin->avg,fin->sum);

for(i=0;i<SN;i++)

printf("%02f\t",fin->score[i]);

putchar(10);

}

/输出一个链表头部/

void print_a_head()

{

int i;

printf("number\tname\tavg\tsum\t");

for(i=0;i<SN;i++)

printf("score%d\t",i+1);

putchar(10);

}

/输出 *** 作菜单/

void print_menu_list()

{

printf("======the operation menu list======\n");

printf("[0]-->exit\n[1]-->creat a list\n[2]-->print the list\n[3]-->insert a list node\n[4]-->select by number\n[5]-->select by name\n");

printf("[6]-->delete a list node\n[7]-->update a list node\n[8]-->order the list by score\n[9]-->print the operation menu list\n");

printf("======the operation menu list======\n");

putchar(10);

}

/输出链表/

int print_list(STU stu)

{

STU p=stu;

if(stu==NULL)

{

printf("no records!!!\n");

return (0);

}

print_a_head();

while(p!=NULL)

{

print_a_node(p);

p=p->next;

}

putchar(10);

return (0);

}

/插入链表单元/

void insert(STU stu)

{

STU tail=stu,p;

printf("now insert a list node\n");

while(tail->next!=NULL)

{

tail=tail->next;

}

p=creat_node();

tail->next=p;

printf("Insert end\n\n");

}

/查找链表num/

STU find_num(STU stu, char num[])

{

STU p=stu,pr=NULL;

while(p!=NULL)

{

if(strcmp(p->num,num)==0){pr=p;break;}

p=p->next;

}

return pr;

}

/查找链表name/

STU find_name(STU stu, char name[])

{

STU p=stu,pr=NULL;

while(p!=NULL)

{

if(strcmp(p->name,name)==0){pr=p;break;}

p=p->next;

}

return pr;

}

/删除链表单元/

STU delet(STU stu, char name[])

{

STU p=stu,front=stu;

if((p=find_name(stu,name))!=NULL)

{

printf("the delete record:\n");

print_a_head();

print_a_node(p);

}

else

{

printf("can not find the student!\n");

return stu;

}

p=stu;

while(p!=NULL&&strcmp(p->name,name)!=0)

{

front=p;

p=p->next;

}

if(p==stu&&front==stu)stu=NULL;

else front->next=p->next;

if(p!=NULL)p->next=NULL;

free(p);

printf("delete end\n\n");

return stu;

}

/更新链表单元/

void update(STU stu, char name[])

{

STU fin;

if((fin=find_name(stu,name))!=NULL)

{

printf("before update:\n");

print_a_head();

print_a_node(fin);

}

else

{

printf("can not find the student!\n");

exit(0);

}

printf("please input the new records now\n");

input(fin);

printf("update end\n\n");

}

/链表单元排序/

void order(STU stu)

{

STU pi,pj,max,temp;

int i;

if(stu!=NULL&&stu->next!=NULL)

{

for(pi=stu;pi!=NULL;pi=pi->next)

{

max=pi;

for(pj=pi->next;pj!=NULL;pj=pj->next)

{

if(max->sum<pj->sum)

max=pj;

}

if(max!=pi)

{

strcpy(tempnum,max->num);

strcpy(max->num,pi->num);

strcpy(pi->num,tempnum);

strcpy(tempname,max->name);

strcpy(max->name,pi->name);

strcpy(pi->name,tempname);

tempsum=pi->sum;

pi->sum=max->sum;

max->sum=tempsum;

tempavg=max->avg;

max->avg=pi->avg;

pi->avg=tempavg;

for(i=0;i<SN;i++)

{

tempscore[i]=max->score[i];

max->score[i]=pi->score[i];

pi->score[i]=tempscore[i];

}

}

}

printf("order end\n\n");

}

else

printf("do not need to order\n\n");

}

/释放链表/

void fre(STU stu)

{

STU p=stu,pf;

if(stu==NULL)

{

printf("the list is NULL!\n");

exit(0);

}

while(p!=NULL)

{

pf=p->next;

free(p);

p=pf;

}

if(stu==NULL)

printf("free the list\n");

}

STU menu(STU stu,int cas)

{

STU fin=NULL;

char a[10];

switch(cas)

{

//创建链表

case 1:

if(stu!=NULL)fre(stu);

stu=creat_list();

break;

//输出链表

case 2:

if(stu==NULL){printf("can not do this operation!\n");putchar(10);break;}

print_list(stu);

break;

//插入链表单元

case 3:

if(stu==NULL){printf("can not do this operation!\n");putchar(10);break;}

insert(stu);

break;

//查找输出number

case 4:

if(stu==NULL){printf("can not do this operation!\n");putchar(10);break;}

printf("please input the 'number' you want to find:\n");

scanf("%s",a);

if((fin=find_num(stu,a))!=NULL)

{

print_a_head();

print_a_node(fin);

}

else printf("no found!\n");

break;

//查找输出name

case 5:

if(stu==NULL){printf("can not do this operation!\n");putchar(10);break;}

printf("please input the 'name' you want to find:\n");

scanf("%s",a);

if((fin=find_name(stu,a))!=NULL)

{

print_a_head();

print_a_node(fin);

putchar(10);

}

else printf("no found!\n");

break;

//删除链表单元

case 6:

if(stu==NULL){printf("can not do this operation!\n");putchar(10);break;}

printf("please input the 'name' you want to delete:\n");

scanf("%s",a);

stu=delet(stu,a);

break;

//更新链表单元

case 7:

if(stu==NULL){printf("can not do this operation!\n");putchar(10);break;}

printf("please input the 'name' you want to update:\n");

scanf("%s",a);

update(stu,a);

break;

//链表单元排序

case 8:

if(stu==NULL){printf("can not do this operation!\n");putchar(10);break;}

printf("order by score\n");

order(stu);

break;

//打印链表 *** 作菜单

case 9:

print_menu_list();

break;

default:

printf("can not do this operation!\n");putchar(10);break;

}

return stu;

}

void main()

{

STU stu=NULL;

int cas;

//打印 *** 作提示

print_menu_list();

//用户 *** 作

do

{

printf("press 0~9 to choose operation!\n");

scanf("%d",&cas);

if(cas<0||cas>9){printf("you must press 0 to 9 !\n");continue;}

if(cas!=0)stu=menu(stu,cas);

if(cas==0){printf("operation end !\n\n");fre(stu);}

}while(cas!=0);

//释放链表

fre(stu);

}

我给你做的是20个人的,至于科目数,你加一下就够了

#include<stdioh>

#include<stringh>

#define N 20//定义学生的个数

struct student//学生的结构体

{

int num;

char name[8];

int yuwen;

int shuxue;

int yingyu;

int wuli;

}st[N];

void main()

{

struct student t;

//用于后面做冒泡排序时的中间变量

printf("输入%d名学生的相关信息:\n",N);

//N是你在前面用宏定义的

//你要输入几个学生的信息改变N值就可以了

printf("\n");

printf("学号 姓名 语文 数学 英语 物理\n");

for(int i=0;i<N;i++)

scanf("%d%s%d%d%d%d",&st[i]num,st[i]name,&st[i]yuwen,&st[i]shuxue,&st[i]yingyu,&st[i]wuli);

printf("\n");

printf("学号 姓名 平均分\n");

double avr[N];

for(i=0;i<N;i++)

{

avr[i]=(st[i]yuwen+st[i]shuxue+st[i]yingyu+st[i]wuli)/40;

printf("%d\t\t%s\t%2lf",st[i]num,st[i]name,avr[i]);

//注意这里的2lf是说保留两位小数的格式描述符2的意思是几位小数位

printf("\n");

}

printf("输入你要查询学生的序号,是第几个学生\n");

scanf("%d",&i);

printf("学号 姓名 语文 数学 英语 物理\n");

printf("%d\t\t%s %d %d %d %d\n",st[i-1]num,st[i-1]name,st[i-1]yuwen,st[i-1]shuxue,st[i-1]yingyu,st[i-1]wuli);

//这是用来选择你要排序的种类的,注意是中文的输入

printf("按照语文成绩进行排序:\n");

printf("\n");

//下面是冒泡排序

//例如按照语文成绩排序

for(i=0;i<N-1;i++)

for(int j=0;j<N-i-1;j++)

if(st[j]yuwen<=st[j+1]yuwen)

{

t=st[j];

st[j]=st[j+1];

st[j+1]=t;

}

printf("学号 姓名 语文 数学 英语 物理\n");

for(i=0;i<N;i++)

printf("%d\t\t%s %d %d %d %d\n",st[i]num,st[i]name,st[i]yuwen,st[i]shuxue,st[i]yingyu,st[i]wuli);

//不及格的人

printf("\n");

//这里必须要在算品均成绩,应为交换之后,顺序变了

for(i=0;i<N;i++)

avr[i]=(st[i]yuwen+st[i]shuxue+st[i]yingyu+st[i]wuli)/40;

printf("不及格人名单如下:\n");

printf("学号 姓名 语文 数学 英语 物理\n");

for(i=0;i<N;i++)

if(avr[i]<600)

printf("%d\t\t%s %d %d %d %d\n",st[i]num,st[i]name,st[i]yuwen,st[i]shuxue,st[i]yingyu,st[i]wuli);

}

以上就是关于用C语言编写一个车票管理系统全部的内容,包括:用C语言编写一个车票管理系统、C语言程序设计的图书管理系统、C语言程序设计学生信息管理系统等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9445016.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存