| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1433 人关注过本帖
标题:!重新修改了一下,,
只看楼主 加入收藏
天下第二刀
Rank: 3Rank: 3
等 级:新手上路
威 望:8
帖 子:157
专家分:0
注 册:2007-1-8
收藏
 问题点数:0 回复次数:18 
!重新修改了一下,,

才学时间不常,只为增加点信心兴趣,呵呵
可能会有很多问题,请多多指教了

#include <iomanip>
#include <iostream>
#include <fstream>
#include <vector>
#include <conio.h>
#include <stdlib.h>
#include <string>
#include <process.h>
#include <stdio.h>
using namespace std;

struct student
{
char name[10]; /// 姓名
char id[10]; /// 学号
float total; /// 总分
student *next;
};
//////////////////////////////////////////////////////////////

class stud
{
student *p1,*p2,*head;
public:

~stud() /////----析构函数------------------------
{

while(head)
{
p1=head->next;
delete head;
head=p1;
}
}
///-------------------------------------------------------------
void output(student *head); // 输出学生成绩
student * insert(student *head); // 增加学生记录
student* del(student *head, char*p); // 删除记录
int find(student *head,char *p) ; // 查找学生记录
student* stat(student *head); //排序统计函数
};

////////-----输出学生成绩-----------------/////////////////////
void stud::output (student *head)
{ p1=head;
if(head==NULL)
cout<<"对不起,这是空表,没有数据"<<endl;
while(p1!=NULL)
{
cout<<p1->name<<" "<<p1->id<<" "<<p1->total<<endl;
p1=p1->next ;
}
}
//////////-----------排序统计函数-----------/////////////////
student *stud::stat(student *head)
{
if(head==NULL)
{cout<<"错误,这还是一张空表"<<endl;
return head;
}

p2=head;
p1=p2->next;

while(p2->next) //冒泡泡法, 呵呵`~~~
{

if(p2->total > p1->total)
{ // 把头指针指向当前比较小的节点
p2->next=p1->next;
p1->next=head;
head=p1;

// 把用于比较的两个指针复位
p2=head;
p1=p2->next ;
}//----------------------------------------
else
{ // 指向下一个节点
p2=p2->next ;
p1=p2->next ;
}//-------------------------------------------

}
cout<<"按学生总分排序成功"<<endl;
return head;
}

/////-----------删除记录-----------//////////////////////
student* stud::del (student *head,char *p)
{
p1=head;
p2=NULL;
if(head==NULL)
{
cout<<"ERROR, 这是一个空表!!"<<endl;
return head;
}

while(strcmp(p1->name ,p)&& p1->next !=NULL)
{ p2=p1;
p1=p1->next ;
}

if(!strcmp(p1->name ,p))
{
if(p1==head)
head=p1->next;
else
p2->next=p1->next ;

cout<<"删除成功,OK"<<endl;
delete p1;
}
else
cout<<" 没找到姓名"<<p<<"的学生.\n"; //结点没找到

return head ;
}

///////-------------查找函数----------///////////////////
int stud::find (student *head,char *p)
{
if(head ==NULL)
{
cout<<"错误,这是一张空表"<<endl; return 1;
}
p2=head;

while(strcmp(p2->name ,p) && p2->next !=NULL)
p2=p2->next ;
if(!strcmp(p2->name,p))
{
cout<<"姓名, 学号, 总分!!!"<<endl;
cout<<p2->name<<" "<<p2->id<<" "<<p2->total<<endl;
}
else
cout<<"对不起,没有您要查找学生的记录"<<endl;

return 0;
}

///////----------------增加学生记录-----------////////////////////////////
student *stud::insert (student *head)
{ p1=new student;
p2=head;
cout<<"姓名, 学号, 总分!!!"<<endl;
cin>>p1->name>>p1->id >>p1->total ;
if(head ==NULL)
{
head=p1;
p1->next =NULL;
return head;
}
while(p2->next !=NULL)
p2=p2->next;
p2->next=p1;
p1->next=NULL;

return head;
}

///////////////////------------main函数--------//////////////////-----------
int main(void)
{
stud stu;
student *head=NULL;
char choice;
char name[10];
while(1)
{ system("cls");
cout<<"┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓";
cout<<"┃**************** 学生成绩管理系统主菜单界面 ****************** ┃";
cout<<"┃********** ★★★★★ ★★★★★★★ ★★★★★ *********** ┃";
cout<<"┣━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┫";
cout<<"┃****************★ ①.增加学生成绩 ★****************┃";
cout<<"┃****************★ ②.显示学生成绩 ★****************┃";
cout<<"┃****************★ ③.排序统计成绩 ★****************┃";
cout<<"┃****************★ ④.查找学生成绩 ★****************┃";
cout<<"┃****************★ ⑤.删除学生成绩 ★****************┃";
cout<<"┃****************★ ⑥.安全退出系统 ★****************┃";
cout<<"┃ ┃";
cout<<"┗━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┛";
cout<<" 请输入您的选择(0--6):";cout<<endl;
cin>>choice; fflush(stdin);
if(choice=='6')
{ cout<<"谢谢使用,再见"<<endl;
exit(0);
}
switch(choice)
{
case '1':
head=stu.insert (head);
break;
case '2':
cout<<"姓名, 学号, 总分!!!"<<endl;
stu.output (head);
getch();
break;
case '3':
head=stu.stat(head);
getch();
break;
case '4':
cout<<"请输入想要查找的学生姓名"<<endl;
cin>>name;

stu.find(head,name);
getch();
break;
case '5':
cout<<"请输入想要删除学生姓名"<<endl;

cin>>name;
head=stu.del(head,name);
getch();
break;

default :
cout<<" 对不起,您的输入有误,请重新输入。\n";
getch();
break;
}
}
getch();
return 0;
}
///***********************************************************************

[此贴子已经被作者于2007-3-31 17:38:28编辑过]

搜索更多相关主题的帖子: include next total 
2007-03-23 22:08
wuji3044
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2006-12-25
收藏
得分:0 

太好了,LZ 高手

2007-03-23 23:42
song4
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:38
帖 子:1533
专家分:4
注 册:2006-3-25
收藏
得分:0 
呵呵
很简便的小程序
努力

嵌入式 ARM 单片机 驱动 RT操作系统 J2ME LINUX  Symbian C C++ 数据结构 JAVA Oracle 设计模式 软件工程 JSP
2007-03-24 08:36
yuyunliuhen
Rank: 6Rank: 6
等 级:贵宾
威 望:20
帖 子:1435
专家分:0
注 册:2005-12-12
收藏
得分:0 
不错,加油!

Go confidently in the  directions of your dreams,live the life you have imagined!Just do it!
It is no use learning without thinking!
2007-03-24 12:20
zhtq301
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2007-3-24
收藏
得分:0 
呵呵
2007-03-24 13:48
软件探讨
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2007-3-19
收藏
得分:0 
简直就是一个高手啊!!
以后请多多指教啊
能留个你的QQ号吗?

2007-03-25 20:33
ttktws
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2007-3-26
收藏
得分:0 
楼主高手啊 以后有问题要请教的话 希望能给些指点  谢谢
2007-03-26 17:59
gaoxing
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2007-3-25
收藏
得分:0 

不错啊,加油

2007-03-26 18:11
songyongjian
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2007-3-26
收藏
得分:0 
  我也是刚学,感觉很晕。实在对不住了。

2007-03-26 18:14
bobee
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2007-3-23
收藏
得分:0 
LZ  厉害哟  值得学习
2007-03-26 22:41
快速回复:!重新修改了一下,,
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.023327 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved