• 回答数

    4

  • 浏览数

    325

wangxinrose
首页 > 学术期刊 > 数据结构课程设计论文格式

4个回答 默认排序
  • 默认排序
  • 按时间排序

七月的尾巴

已采纳

我写过一个类似的。。学生管理程序用 c# 写的。。 用到了sql 2005数据结构用到了 链表 kmf模糊查询楼主需要不?

337 评论

厦门小鱼网

#include <>#include <>#include <>//#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;imid&&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;j0) //看现库存是否大于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;inext)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;iBNum,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;kCardNum); 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;iBNum); //书号 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;iRetDate,date)<0) //超过日期 { printf("书号为 %s 证号为 %s 应归还日期为 %s \n",p->BNum,Lin[i].CNum,p->RetDate); }//显示所有超期未还的书的信息 p=p->next; } }}void Menu() //菜单{ printf("┏—————————————————M E N U————————————————┓\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");}void 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); break; 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; } }}

346 评论

wangeunice

一 需求分析:在该部分中根据设计题目的要求,充分地分析和理解问题,叙述系统的功能要求,明确问题要求做什么?以及限制条件是什么?1.1问题描述1.2基本要求(1) 输入的形式和输入值的范围;(2) 输出的形式;(3) 程序所能达到的功能;二 概要设计说明本程序中用到的所有抽象数据类型的定义。主程序的流程以及各程序模块之间的层次(调用)关系。1、 数据结构2、 程序模块3、各模块之间的调用关系以及算法设计三 详细设计实现概要设计中定义的所有数据类型,对每个操作写出伪码算法;对主程序和其他模块也都需要写出伪码算法(伪码算法达到的详细程度建议为:按照伪码算法可以在计算机键盘直接输入高级程序设计语言程序);写出出函数和过程的调用关系.四 测试与分析测试数据,输出测试的结果,这里的测试数据应该完整和严格。并对结果进行分析。五 总结总结可以包括 : 课程设计过程的收获、遇到问题、遇到问题解决问题过程的思考、程序调试能力的思考、对数据结构这门课程的思考、在课程设计过程中对《数据结构》课程的认识等内容。

182 评论

Lydia胖胖

好像没有数据结构的 你试试c++语言面向对象程序设计课程设计 这个网站能免费下几个,不能免费下的就要收费了本站免费计算机课程设计论文下载本人原创计算机类课程设计免费下载,销售计算机毕业论文请把我的网站介绍给同学们.谢谢支持本站ACCESS课程设计库存管理工资管理系统 sqlserver数据库课程设计 c++语言面向对象程序设计课程设计 vb课程设计学生成绩系统asp留言板(没有论文) 计算机实训计算机组装与维护课程设计简单的网页设计没有论文 office课程设计 操作系统课程设计另有以上没有列出的计算机课程设计为收费材料30元一份 更多

316 评论

相关问答

  • 结构设计论文答辩过程

    一、按分组名单上指定的教室集中,由领导或主持答辩的老师发言。二、按顺序进行答辩,步骤如下:1、简单介绍自己就读专业;2、陈述自己选题的背景、目的,一般先让学员概

    A明天你好! 5人参与回答 2023-12-11
  • 电赛课程设计论文格式

    课程设计开题报告格式 每个人都要经历写课程设计开题报告,下面就由我为大家整理课程设计开题报告格式,欢迎大家查看! 课程设计开题报告格式1 1、开题报告写作格式

    郭嘎嘎2222 2人参与回答 2023-12-05
  • 数据库设计论文格式

    1、题目。应能总结整篇论文最重要的内容,言简意赅,引人注目,一般不能超过20个字。2、论文摘要及关键词。论文摘要应阐述论文的主要观点。说明论文的目的、研究方法、

    雨丰是小兔 4人参与回答 2023-12-06
  • 百度文库数电课程设计论文格式

    一、课程设计(论文)资料的组成 1.课程设计(论文)任务书; 2.课程设计(论文)——标题、中英文摘要(关键词)、正文、参考文献; 3.课程设

    蝶澈0825 2人参与回答 2023-12-08
  • 毕业课程设计论文格式

    论文正文格式 论文的正文是论文的核心部分,那么,论文的正文格式是怎样的呢?下面是我分享的论文正文格式,欢迎阅读! 论文正文的格式 1.论文正文包括引言和正文论述

    木木停留 3人参与回答 2023-12-06