1、c++ 课程管理系统设计与实现
这个做过好久了,找不到当时成型的那个了,给你这个看看吧,没运行,你把没用的删掉,改改,自己运行试试
#include <stdio.h>
#include<stdlib.h>
#include<string.h>
int savedTag=0;
struct student
{ char name[20];
int num;
char sex[4];
float math,english,history,SQL,C;
float sum;
float avg;
int order;
};
typedef struct Node
{ struct data;
struct Node *next;
}Node,*Link;
void menu()
{printf (“*******************************************************************\n”);
printf (“\t\t\t\t\t\t1增加学生资料\t\t\t\t\t\t\t\t\t\2删除学生资料\n”);
printf (“\t\t\t\t\t\t3查询学生资料\t\t\t\t\t\t\t\t\t\4修改学生资料\n”);
printf (“\t\t\t\t\t\t5保存学生资料\t\t\t\t\t\t\t\t\t\6显示学生资料\n”);
printf (“\t\t\t\t\t\t7对学生资料进行分类\t\t\t\t\t\t\8从记录文件中读取学生资料\n”)
printf (“\t\t\t\t\t\t9新建学生资料文件\t\t\t\t\t\t\t\0推出系统\n”);
printf (“*******************************************************************\n”);
}
void printstart()
{printf("--------------------------------------------------------------------\n");}
void Wrong()
{printf("\n====>提示:输入错误!\n");}
void Nofind()
{printf("\n====>提示:没有找到该学生!\n");}
void printc()
{printf("学号\t姓名\t性别\t数学成绩\t英语成绩\t历史成绩\t专业成绩\tC语言成绩\t总分\t平均分\t名次\n");}
void printe()
{printf("%-12s%\t%s\s%s\s%f\t%f\t%f\t%f\t%f\t%f\t%f\t%d\n",
p->data.num,p->data.name,p->data.sex,p->data.math,p->data.english,p->data.history,p->data.SQL,p->data.C,p->data.sum,p->data.avg,p->data.order);}
Node *Locate(Link1,char findmess[],char nameornum[])
/*该指针函数用于定位链表中符合要求的节点,并返回指针(即从链表的某个当前节点查找跟findmess中名字相同的信息节点)*/
/*第一个参数l表示指向的当前节点*/
{Node *r; /* 指向链表中的某个节点 */
if(strcmp(nameornum,"name")==0) /* 按姓名查询 */ /*核对本函数传入的第三个参数(数组)是否为字符串"name" */
{
r=l->next; /*指向(当前节点的)下一个节点 */
while(r!=NULL) /*如果下个节点不为空*/
{
if(strcmp(r->data.name,findmess)==0) /比较"下个"节点的数据域的"名字"是否为传入的第二个参数指定的名字*/
return r; /*如果找到了匹配的名字则返回该节点*/
r=r->next; /*否则继续查找下个节点,直到链表的结尾*/
}
}
【else if(strcmp(nameornum,"num")==0)]】 【到底是那个语句?? 类型不对能行吗?是要跟“num”比较,还是跟num的数值比较? 】
else if(num==(int)nameornum) /*按学号查询*/
{r=1->next;
while(r!=NULL)
{if(strcmp(r->data.num,findmess)==0)
return r;
r=r->next;
}
}
【if(strcmp(nameornum,"order")==0) 】
else if(order==(int)nameiornum) /*按名次查询*/
{r=1->next;
while(r!=NULL)
{if(strcmp(r->data.order,findmess)==0)
return r;
r=r->next;
}
}
return 0;
}
void Add(Link l) /* 增加学生 */
{
Node *p,*r,*s;
char num[10];
r=l;
s=l->next;
while(r->next!=NULL)
r=r->next; /*否则继续查找下个节点,直到链表的结尾(将指针置于最末尾 )*/
while(1)
{
printf("请你输入学号(以'0'返回上一级菜单");
scanf("%s",num);
if(num==0) /*学号输入遇0结束*/
break;
while(s)
{
if(s->data.num==num)
{
printf("=====>提示:学号为'%s'的学生已经存在,若要修改请你选择'4 修改'!\n",num);
printstart();
printc();
printe(s);
printstart();
printf("\n");
return;
}
s=s->next; /*否则继续查找下个节点,直到链表的结尾(将指针置于最末尾 )*/
}
p=(Node *)malloc(sizeof(Node)); /*动态分配内存*/
p->data.num=num
printf("请你输入姓名:");
scanf("%s",p->data.name);
getchar();
printf("请你输入性别:");
scanf("%s",p->data.sex);
getchar();
printf("请你输入数学成绩:");
scanf("%f",&p->data.math);
getchar();
printf("请你输入英语成绩:");
scanf("%f",&p->data.english);
getchar();
printf("请你输入历史成绩:");
scanf("%f",&p->data.history);
getchar();
printf("请输入资料成绩:");
scanf("%f",&p->data.SQL);
getchar();
printf("请输入专业成绩:");
scanf("%f",&p->data.C);
getchar(); /* 信息输入已经完成 */
s->sum=s->math+s->english+s->SQL+s->C+s->history; /*求总成绩*/
s->avg=s->sum/5; /*求平均值*/
p->next=NULL;
r->next=p;
r=p;
savedTag=1; /*改变存储标志*/
}
}
void Qur(Link l) /* 查询学生 */
{
int sel;
char findmess[20]; 【这里定义的这个findmess跟前面的指针函数没关系吧?】
Node *p;
if(!l->next)
{
printf("\n=====>提示:没有资料可以查询!\n");
return;
}
printf("\n=====>1按学号查找\n=====>2按姓名查找\n====>3按名次查找\n");
scanf("%d",&sel);
if(sel==1) /* 按学号 查找*/
{
printf("请你输入要查找的学号:");
scanf("%d",&(int)findmess); 【学号是int类型的,所以把findmess转换为int类型】
p=Locate(l,findmess,"num"); 【原函数中的第三个参数的类型为char,那么这里写“num”对吗?
加了双引号,代表代表这里是字符串而不是num的int类型的数值,是么?】
if(p)
{
printf("\t\t\t\t查找结果\n");
printstart();
printc();
printe(p);
printstart();
}
else
Nofind();
}
else if(sel==2) /* 按姓名查找 */
{
printf("请你输入要查找的姓名:");
scanf("%s",findmess);
p=Locate(l,findmess,"name");
if(p)
{
printf("\t\t\t\t查找结果\n");
printstart();
printc();
printe(p);
printstart();
}
else
Nofind();
}
else if(sel==3) /* 按名次查找 */
{
printf("请你输入要查找的名次:");
scanf("%d",&(int)findmess);
p=Locate(l,findmess,"order");
if(p)
{
printf("\t\t\t\t查找结果\n");
printstart();
printc();
printe(p);
printstart();
}
else
Nofind();
}
else
Wrong();
}
void Del(Link l) /* 删除学生信息 */
{
int sel,s;
Node *p,*r;
char findmess[20];
if(!l->next)
{
printf("\n=====>提示:没有资料可以删除!\n");
return;
}
printf("\n=====>1按学号删除\n=====>2按姓名删除\n====>3按名次删除\n");
scanf("%d",&sel);
if(sel==1)
{
printf("请你输入要删除的学号:");
scanf("%s",findmess);
printf("\n====>警告:确定删除信息?(y\n):") ;
scanf("%c",&s);
if(s=='y'||s=='Y')
{p=Locate(l,findmess,"num");
if(p)
{
r=l;
while(r->next!=p)
r=r->next;
r->next=p->next;
free(p);
printf("\n=====>提示:该学生已经成功删除!\n");
savedTag=1;
}
else
Nofind();
}
else exit(0);
}
else if(sel==2)
{
printf("请你输入要删除的姓名:");
scanf("%s",findmess);
printf("\n====>警告:确定删除信息?(y\n):") ;
scanf("%c",&s);
if(s=='y'||s=='Y')
{p=Locate(l,findmess,"name");
if(p)
{
r=l;
while(r->next!=p)
r=r->next;
r->next=p->next;
free(p);
printf("\n=====>提示:该学生已经成功删除!\n");
savedTag=1;
}
else
Nofind();
}
else exit(0);
}
else if(sel==3)
{
printf("请你输入要删除的名次:");
scanf("%d",&findmess);
printf("\n====>警告:确定删除信息?(y\n):") ;
scanf("%c",&s);
if(s=='y'||s=='Y')
{p=Locate(l,findmess,"order");
if(p)
{
r=l;
while(r->next!=p)
r=r->next;
r->next=p->next;
free(p);
printf("\n=====>提示:该学生已经成功删除!\n");
savedTag=1;
}
else
Nofind();
}
else exit(0);
}
else
Wrong();
}
void Modify(Link l)
{ int sel,s;
Node *p;
char findmess[20];
if(!l->next)
{
printf("\n=====>提示:没有资料可以修改!\n");
return;
}
printf("\n=====>1按学号修改\n=====>2按姓名修改\n====>3按名次修改\n");
scanf("%d",&sel);
if(sel==1)
{printf("请你输入要修改的学生学号:");
scanf("%d",&(int)findmess);
printf("\n====>警告:确定修改信息?(y\n):") ;
scanf("%c",&s);
if(s=='y'||s=='Y')
{p=Locate(l,findmess,"num");
if(p)
{
printf("请你输入新学号:");
scanf("%d",&p->data.num);
printf("请你输入新姓名:");
scanf("%s",p->data.name);
getchar();
printf("请你输入新性别:");
scanf("%s",p->data.sex);
printf("请你输入新的数学成绩:");
scanf("%f",&p->data.math);
getchar();
printf("请你输入新的英语成绩:");
scanf("%f",&p->data.english);
getchar();
printf("请你输入新的历史成绩:");
scanf("%f",&p->data.history);
printf("请输入新的资料成绩:");
scanf("%f",&p->data.SQL);
printf("请你输入新的专业成绩:");
scanf("%f",&p->data.C);
printf("\n=====>提示:资料修改成功!\n");
s->sum=s->math+s->english+s->SQL+s->C+s->history;
s->avg=s->sum/5;
savedTag=1;
}
else
Nofind();
}
else exit(0) ;
}
else if(sel==2)
{printf("请你输入要修改的学生姓名:");
scanf("%s",findmess);
printf("\n====>警告:确定修改信息?(y\n):") ;
scanf("%c",&s);
if(s=='y'||s=='Y')
{p=Locate(l,findmess,"name");
if(p)
{
printf("请你输入新姓名:");
scanf("%s",p->data.name);
getchar();
printf("请你输入新学号:");
scanf("%d",&p->data.num);
printf("请你输入新性别:");
scanf("%s",p->data.sex);
printf("请你输入新的数学成绩:");
scanf("%f",&p->data.math);
getchar();
printf("请你输入新的英语成绩:");
scanf("%f",&p->data.english);
getchar();
printf("请你输入新的历史成绩:");
scanf("%f",&p->data.history);
printf("请输入新的资料成绩:");
scanf("%f",&p->data.SQL);
printf("请你输入新的专业成绩:");
scanf("%f",&p->data.C);
printf("\n=====>提示:资料修改成功!\n");
s->sum=s->math+s->english+s->SQL+s->C+s->history;
s->avg=s->sum/5;
savedTag=1;
}
else
Nofind();
}
else exit(0) ;
}
else if(sel==3)
{printf("请你输入要修改的学生名次:");
scanf("%d",&(int)findmess);
printf("\n====>警告:确定修改信息?(y\n):") ;
scanf("%c",&s);
if(s=='y'||s=='Y')
{p=Locate(l,findmess,"order");
if(p)
{
printf("请你输入新学号:");
scanf("%d",&p->data.num);
printf("请你输入新姓名:");
scanf("%s",p->data.name);
getchar();
printf("请你输入新性别:");
scanf("%s",p->data.sex);
printf("请你输入新的数学成绩:");
scanf("%f",&p->data.math);
getchar();
printf("请你输入新的英语成绩:");
scanf("%f",&p->data.english);
getchar();
printf("请你输入新的历史成绩:");
scanf("%f",&p->data.history);
printf("请输入新的资料成绩:");
scanf("%f",&p->data.SQL);
printf("请你输入新的专业成绩:");
scanf("%f",&p->data.C);
printf("\n=====>提示:资料修改成功!\n");
s->sum=s->math+s->english+s->SQL+s->C+s->history;
s->avg=s->sum/5;
savedTag=1;
}
else
Nofind();
}
else exit(0) ;
}
}
/*************************************************************************************/
void Disp(Link l)
{
int count=0;
Node *p;
p=l->next;
if(!p)
{
printf("\n=====>提示:没有资料可以显示!\n");
return;
}
printf("\t\t\t\t显示结果\n");
printstart();
printc();
printf("\n");
while(p)
{
printe(p);
p=p->next;
}
printstart();
printf("\n");
}
/*************************************************************************************/
void Tongji(Link l)
{
Node *pm,*pe,*pc; /* 用于指向分数最高的接点 */
Node *r=l->next;
if(!r)
{
printf("\n=====>提示:没有资料可以统计!\n");
return ;
}
pm=pe=pc=r;
while(r!=NULL)
{
if(r->data.age>=pc->data.age)
pc=r;
if(r->data.birth>=pm->data.birth)
pm=r;
if(r->data.tele>=pe->data.tele)
pe=r;
r=r->next;
}
}
/*************************************************************************************/
void Sort(Link l)
{
Link ll;
Node *p,*rr,*s;
ll=(Link)malloc(sizeof(Node)); /* 用于做新的连表 */
ll->next=NULL;
if(l->next==NULL)
{
printf("\n=====>提示:没有资料可以排序!\n");
return ;
}
p=l->next;
while(p)
{
s=(Node*)malloc(sizeof(Node)); /* 新建接点用于保存信息 */
s->data=p->data;
s->next=NULL;
rr=ll;
while(rr->next!=NULL )
rr=rr->next;
if(rr->next==NULL)
rr->next=s;
else
{
s->next=rr->next;
rr->next=s;
}
p=p->next;
}
free(l);
l->next=ll->next;
printf("\n=====>提示:排序已经完成!\n");
}
/*************************************************************************************/
void Save(Link l)
{
FILE* fp;
Node *p;
int flag=1,count=0;
fp=fopen("c:\\student","wb");
if(fp==NULL)
{
printf("\n=====>提示:重新打开文件时发生错误!\n");
exit(1);
}
p=l->next;
while(p)
{
if(fwrite(p,sizeof(Node),1,fp)==1)
{
p=p->next;
count++;
}
else
{
flag=0;
break;
}
}
if(flag)
{
printf("\n=====>提示:文件保存成功.(有%d条记录已经保存.)\n",count);
shoudsave=0;
}
fclose(fp);
}
/*************************************************************************************/
void main()
{
Link l;/* 连表 */
FILE *fp; /* 文件指针 */
int sel;
char ch;
char jian;
int count=0;
Node *p,*r;
printf("\t\t\t\t学生成绩管理系统\n\t\t\t\t-------信息工程学院通信XXX\n");
l=(Node*)malloc(sizeof(Node));
l->next=NULL;
r=l;
fp=fopen("C:\\student","rb");
if(fp==NULL)
{
printf("\n=====>提示:文件还不存在,是否创建?(y/n)\n");
scanf("%c",&jian);
if(jian=='y'||jian=='Y')
fp=fopen("C:\\student","wb");
else
exit(0);
}
printf("\n=====>提示:文件已经打开,正在导入记录......\n");
while(!feof(fp))
{
p=(Node*)malloc(sizeof(Node));
if(fread(p,sizeof(Node),1,fp)) /* 将文件的内容放入接点中 */
{
p->next=NULL;
r->next=p;
r=p; /* 将该接点挂入连中 */
count++;
}
}
fclose(fp); /* 关闭文件 */
printf("\n=====>提示:记录导入完毕,共导入%d条记录.\n",count);
while(1)
{
menu();
printf("请你选择操作:");
scanf("%d",&sel);
if(sel==0)
{
if(shoudsave==1)
{ getchar();
printf("\n=====>提示:资料已经改动,是否将改动保存到文件中(y/n)?\n");
scanf("%c",&ch);
if(ch=='y'||ch=='Y')
Save(l);
}
printf("\n=====>提示:你已经退出系统,再见!\n");
break;
}
switch(sel)
{
case 1:Add(l);break; /* 增加学生 */
case 2el(l);break;/* 删除学生 */
case 3ur(l);break;/* 查询学生 */
case 4:Modify(l);break;/* 修改学生 */
case 5:Save(l);break;/* 保存学生 */
case 9:printf("\t\t\t==========帮助信息==========\n");break;
default: Wrong();getchar();break;
}
}
}
2、网络课堂系统的设计与实现
同学课题请自己好好做
3、Java课程网站设计与实现
开题报告
题 目:Java课程网站设计与实现
学 院:xx
专 业:xx
学生姓名:xx
指导教师:xx
日 期:xx-xx-xx
设计(论文)的技术路线及预期目标:
作为课程设计,主要目的是希望通过该系统的设计开发,将所学知识真正的应用于实践当中,培养实际动手能力。并在设计实践过程中,学习到更深的知识,掌握先进的技术。以此来增强对一个系统设计的整体认识,熟悉软件开发过程,更深刻的理解软件工程的知识,熟悉数据库的设计与实现(Oracle),学习和掌握面向对象的分析方法(UML),利用MVC结构来开发高效率、高性能的Web应用程序,及面向对象的程序设计方法(以java语言实现)。
本次课题研究的主要内容是人事管理的需求分析和设计,最终完成一个人事管理系统。
课题进度计划:
我拟订将该研究过程划分为三个阶段,分别为前期、中期和后期。在前期阶段(2—3周),主要做一些准备工作,如熟悉开发环境,认识J2EE架构,学习JAVA语言,MVC架构,收集一些有助于课题研究的资料,并试着写相关的程序。在该阶段需要完成的主要任务是“需求分析”,提出“概要设计方案”。
在中期阶段(4—6周),对项目块进行研究、实验,本阶段是整个研究、设计过程中的一个很重要的时期,也是对整个系统进行详细设计和编码,最后基本完成整个系统的制作任务。
后期阶段(1—3周),该阶段主要对整个系统进行集成和测试,发现系统存在的问题和有那些缺陷,并进行总结和分析,为将来的工作积累经验和教训。
我相信,通过在以上几个阶段中的努力工作及老师的辛勤指导,最后一定能做成电子政务档案管理系统,完成课题研究任务。
我们也希望通过这次课题研究的机会,深层次的了解Java语言的开发及JavaBean和Jsp的使用技巧及MVC构架,掌握先进的软件设计、管理、开发方法。
毕业设计(论文)的主要内容:
本次课题研究的主要内容是人事管理的需求分析和设计,最终完成一个人事管理系统。
在研究过程中,我将应用基于J2EE中的MVC构架技术来实现我的人事系统。拟订将该系统划分为三层,首先通过HTML向客户展示被请求信息的表层(Represent Tier),我们用Java Servlet和JavaServer Page及JSTL来实现;然后是控制逻辑层(Control Logic Tier),它包含了一些在Struts体系结构上运行的组件;最后是数据库层(Database Tier),用于永久性存储数据。
公司管理模块实现了公司的增加、删除、修改、查询等功能。
职位管理模块实现了职位的增加、删除、修改、查询等功能。工作类型管理模块实现了工作类型的增加、删除、修改、查询等功能。部门管理模块实现了部门的增加、删除、修改、查询等功能。
员工管理模块实现了增加、删除、修改、查询等功能。
档案管理系统的系统功能图:
在过去的很大一部分时间里都在熟悉将要采用的开发环境,如今已基本掌握了各开发工具和所必须的知识。针对课题研究对象,在不同的方面进行了研究,如:
需求分析:人事管理系统的主要作用是为用户管理不同公司、不同部门的职工,方便用户的查询、汇总及分析。针对不同的用户,人事管理系统有不同的功能表现。本系统为用户提供对公司人事的管理,具体包括的功能有职位管理、工作类型管理、部门管理、公司管理、员工管理及操作数据库的实现。本系统需要实现以下功能:
1、 公司管理:用户可以增加公司的类别,2、 针对不同3、 类别的公司或者分公司,4、 系统可以按公司类别进行处理。通过公司区分不同5、 的用户。
6、 职位管理:用户可以为本系统的不同7、 公司职工增加职位,8、 来具体区分不同9、 公司的职工的职位类别。
10、 工作类型管理:用户可以为本系统增加工作类型管理,11、 针对不同12、 职工的工作类型进行管理,13、 来区分职工的工作类型。
14、 部门管理:用户可以为本系统增加部门,15、 包括修改、查看、删除、查询等操作。针对不同16、 公司的部门进行管理,17、 建立本公司的部门结构。
18、 员工管理:用户可以为本系统增加员工。针对公司的某部门的员工进行管理,19、 建立本公司某部门的职工管理模块。
系统设计:在大家的努力下,我们现在对整个网上图书销售系统的框架基本达成了一定的共识,具体内容将在详细的设计书中进行描述。
数据库设计:根据对系统的认识和分析,我们已开始设计符合系统要求的后台数据库系统。如:公司信息{公司名称},职位信息{职位名称},工作类型信息{工作类型名称},部门信息{部门信息},员工信息{员工ID,姓名,性别,公司名称,政治面貌,文凭,工作类型编码,工作类型名称,部门名称,出生日期,结束工作日期,参加工作日期,家庭地址,电话,手机,电子邮件,基础工资,信用卡号}。
用户界面设计:在设计研究过程中,已经进行用户界面的设计。我们不仅让设计出来的系统满足需求,还使用户在使用时感到舒适、便捷。
我相信,我的努力及老师的指导下,一定能够圆满的完成这次课题研究任务。
完成课题所需条件及落实措施:
从现有条件和所学课程来看,通过努力均可以完成毕业设计任务。
计算机系机房提供上机条件,设计资料和书籍从学生毕业设计的费用中开支。
完成课题所需条件都已经基本落实。
参考文献、资料:
《J2EE编程技术》 郝玉龙,北方交大出版
《Java程序设计》 朱喜福,人民邮电出版
《J2EE案例开发》 季民,中国水利水电出版
《Java网络编程》 冯博,清华大学出版
《Java程序设计实用教程》 朱战立,人民邮电出版
《Java开放源码编程》 [美]Joe Walnes,电子工业出版
《JBuilder 10入门与提高》 王碧波,清华大学出版
《Java程序设计基础》 (美)Gary,Bronson,北京大学出版
指导教师意见:
指导教师签字:
年 月 日
学院毕业设计(论文)工作领导小组意见:
组长签字:
年 月 日
4、基于java的课程网络考试系统的设计与实现 论文及代码 谁有啊,毕业设计,跪求,急啊,有什么办法
专业定制爬虫,安装版50,附源码100,
私人编程家教300/月
大中型软件定制
网站建设维护
毕业设计
有意回复
5、毕业设计课题“教学网站的设计与实现”的选题依据和意义,求有能力者答疑
选题的依据和意义
随着条件的不断改善,各个学校逐渐建立起计算机机房,传统的教学方式已经无法满足教育的需求。在传统的教学方式中,学生在学习上比较被动消极。说教方式,只能保证学生掌握知识,无法较好地培养学生主动的学习能力,因为大多数时间,老师讲课之中,学生很少能独立发现问题,更无法培养解决问题的能力了。再加上每个学生的水平的差异,不能更好地因材施教,会造成优等生、差等生分化。因此,学校非常有必要建立课程教学网站。而课程教学网站又是集图、文、音、像于一体的知识库,资料库。这样,学生能自我主动学习,探索问题,可以自主分配多余的业余时间,在网站学习、考试。毫无疑问,传统的教学模式再配合上新兴的课程教学网站,更有利于培养学生的综合能力。
6、大学课程作业《某某电子商务网站的设计与实现》。要求:1.设计报告2.网页设计3数据库。
我有以前做的dreamweaver的网页作业。
有20份作业的源文件。任你挑选。
邮箱我就不单独发了,为了方便大家下载参考。
我把网页作业源文件打包上传到我的百度网盘。可以直接下载,不需要注册,也不需要积分。
网页作业的下载地址 公布于本人的百度空间的文章中。
找不到或者有什么问题的可以私信我
7、课题名称:Photoshop实践教学网站的设计与实现;设计要求:设计出PS实践课(实验)的交互网站。
我个人认为,你可以把2者结合起来啊,既然是PS的教学网站,那么你就用PS做啊,自然就一眼看出这个网站教学实力了啊,不矛盾嘛!