注册 登录
编程论坛 C++教室

请教下大家

flysky102 发布于 2008-03-16 20:19, 1119 次点击
程序要求是要记录下捐款人的姓名和金额后,再一一列出捐10000以上的和以下的,我的程序怎么只能记录一个人的数据啊,怎么改是记录多人后再显示?
# include <iostream>
struct tt
 {  char name [20];
    double pace;
 };
 int main()
 {using namespace std;
  tt*jk=new tt;
  cout<<"请输入姓名:";
  cin.get(jk->name,20);
  cout<<"请输入捐款金额:";
  cin>>jk->pace;
  if(jk->pace>10000)
    cout<<"Grand Patrons:"
        <<jk->name;
    else cout<<"Patrons:"<<jk->name;
  
  system("pause");
  return 0;
}
14 回复
#2
wangxinkai2008-03-16 20:23
用指针做。
在指针里排序筛选,
#3
flysky1022008-03-16 20:25
我也想用指针啊,可是我对那个一直处于时而懂时而又不懂了
#4
wangxinkai2008-03-16 20:28
那你就用大数组做,
#5
wangxinkai2008-03-16 20:30
给你个代码吧。。。你自己看去吧。
#6
wangxinkai2008-03-16 20:30
//希望对你有帮助.这个不是我自己写的,是搜集的别人的,写的不错,可以运行。
/**************************************************
内容及要求:
1注册新职工,添加新职工的详细信息,
如:职工号,姓名,出生年份,性别,职称,部门,工资等;
2按姓名,部门等条件进行查询;
3修改和删除职工信息;
4按工资高低进行排序;
5把各项纪录存储在文本文件中。

评说:有删除和增加的操作,最好选取链表来做。
**************************************************/
#include <string>
#include <iostream>
#include <fstream>
#include <iomanip>
#include <memory.h>
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
using namespace std;

struct Employee
{//声明职工的结构作为链表节点。
//-----数据域-----
string m_Code;
string m_Name;
unsigned short int m_Year;
string m_Sex;
string m_Post;
string m_Department;
unsigned int m_Wage;
//链表节点的指针域---
struct Employee* Next;
};

//-----个人习惯:取别名-------
typedef struct Employee Node;
typedef Node* Link;

//-------函数声明-------------
Link Create(Link Head);
void Release(Link Head);
Link Add(Link Head);
bool Search(Link Head);
Link Search_Unique(Link Head);
void Display_List(Link Head);
void Display_Node(Link pNode);
Link Modify(Link Head);
Link Del(Link Head);
void Save_ByFile(Link Head,fstream& ofile);
Link Sort(Link Head);
//-------函数实现--------------------------



Link Create(Link Head)
{//创建一个带头节点的空链表。
Head=(Link)new Node;
if(!Head)
{
cout<<"分配内存失败!"<<endl;
return NULL;
}
Head->m_Code="";
Head->m_Name="";
Head->m_Year=0;
Head->m_Sex="";
Head->m_Post="";
Head->m_Department="";
Head->m_Wage=0;
Head->Next=NULL;

return Head;
}





void Release(Link Head)
{//释放链表。
Link ptr;//声明一个操作用的指针。
while(Head!=NULL)
{
ptr=Head;
Head=Head->Next;
delete ptr;//释放节点资源。
}
}







Link Add(Link Head)
{//前插法添加数据。
Link pNew;// 声明一个新节点。
char again;
string code,name,sex,post,department;
unsigned short int year;
unsigned int wage;
do
{
pNew=(Link)new Node;
//数据域。
cout<<"请输入职工代码:";
cin>>code;
cout<<endl<<"请输入职工姓名:";
cin>>name;
cout<<endl<<"请输入职工出生年份:";
cin>>year;
while(cin.fail())
{
cout<<"请输入正确的年份格式。"<<endl;
cin.clear();
fflush(stdin);
cin>>year;
}
cout<<endl<<"请输入职工性别:";
cin>>sex;
cout<<endl<<"请输入职工职称:";
cin>>post;
cout<<endl<<"请输入职工部门:";
cin>>department;
cout<<endl<<"请输入职工工资:";
cin>>wage;
while(cin.fail())
{
cout<<"请输入正确的工资数据。"<<endl;
cin.clear();
fflush(stdin);
cin>>wage;
}
cout<<endl;
pNew->m_Code=code;
pNew->m_Name=name;
pNew->m_Year=year;
pNew->m_Sex=sex;
pNew->m_Post=post;
pNew->m_Department=department;
pNew->m_Wage=wage;
//指针域。
pNew->Next=Head->Next;
Head->Next=pNew;
cout<<"数据添加成功!是否继续添加?(Y/N)"<<endl;
cin>>again;
}while(again=='Y'||again=='y');
return Head;
}







bool Search(Link Head)
{//查询同时满足“姓名”和“部门”的职工信息。
Link ptr;
string department;
string name;
ptr=Head->Next;
cout<<"请输入部门:";
cin>>department;
cout<<endl<<"请输入姓名:";
cin>>name;
cout<<endl<<"----------------查询结果------------------"<<endl;
while(ptr)
{
if((ptr->m_Name==name)&&(ptr->m_Department==department))
{
Display_Node(ptr);//打印满足条件的节点。
return true;
}
ptr=ptr->Next;//查询下一节点。
}
cout<<"无此职工的信息。"<<endl;
return false;
}






Link Search_Unique_Front(Link Head)
{//查询满足“职工代码“的职工信息(职工代码必需唯一)。
Link ptr;
string code;
ptr=Head;
cout<<"请输入职工代码:";
cin>>code;
cout<<endl<<"----------------查询结果------------------"<<endl;
while(ptr->Next)
{
if(ptr->Next->m_Code==code)
//Display_Node(ptr);//打印满足条件的节点。
return ptr;//注意,是返回的查询到的节点的直接前趋节点。
ptr->Next=ptr->Next->Next;//查询下一节点。
}
return ptr;
}





void Display_List(Link Head)
{
Link ptr;
ptr=Head->Next;
cout<<"==================所有职工信息=================="<<endl;
while(ptr)
{
Display_Node(ptr);
ptr=ptr->Next;
}
}






void Display_Node(Link pNode)
{//在标准输出设备上输出。
cout<<setw(10)<<left<<pNode->m_Code
<<setw(10)<<left<<pNode->m_Name
<<setw(10)<<left<<pNode->m_Year
<<setw(10)<<left<<pNode->m_Sex
<<setw(10)<<left<<pNode->m_Post
<<setw(10)<<left<<pNode->m_Department
<<setw(10)<<left<<pNode->m_Wage<<endl;//setw(10)表示占10个字符位置。
}





Link Modify(Link Head)
{// 修改单一个节点。
Link ptr;
ptr=Search_Unique_Front(Head);
string code,name,sex,post,department;
unsigned short int year;
unsigned int wage;
if(ptr->Next)
{
cout<<"-------你现在可以修改此职工的信息了-------"<<endl;
//数据域。
cout<<"请输入职工代码:";
cin>>code;
cout<<endl<<"请输入职工姓名:";
cin>>name;
cout<<endl<<"请输入职工出生年份:";
cin>>year;
while(cin.fail())
{
cout<<"请输入正确的年份格式。"<<endl;
cin.clear();
fflush(stdin);
cin>>year;
}
cout<<endl<<"请输入职工性别:";
cin>>sex;
cout<<endl<<"请输入职工职称:";
cin>>post;
cout<<endl<<"请输入职工部门:";
cin>>department;
cout<<endl<<"请输入职工工资:";
cin>>wage;
while(cin.fail())
{
cout<<"请输入正确的工资数据。"<<endl;
cin.clear();
fflush(stdin);
cin>>wage;
}
cout<<endl;
ptr->Next->m_Code=code;//因ptr是前趋节点,所以要用ptr->Next;
ptr->Next->m_Name=name;
ptr->Next->m_Year=year;
ptr->Next->m_Sex=sex;
ptr->Next->m_Post=post;
ptr->Next->m_Department=department;
ptr->Next->m_Wage=wage;
}
cout<<"没找到此职工的记录,无法修改。"<<endl;
return Head;
}







Link Del(Link Head)
{
Link ptr;
Link ptr_front;
ptr_front=Search_Unique_Front(Head);
ptr=ptr_front->Next;
if(ptr)
{
ptr_front->Next=ptr->Next;
delete ptr;//删除此节点。
}
cout<<"没找到此职工的记录,无法删除。"<<endl;
return Head;
}






void Save_ByFile(Link Head,fstream& ofile)
{
Link pNode;
pNode=Head->Next;
ofile.clear();//清除文件结束状态。
while(pNode)
{
ofile<<setw(10)<<left<<pNode->m_Code
<<setw(10)<<left<<pNode->m_Name
<<setw(10)<<left<<pNode->m_Year
<<setw(10)<<left<<pNode->m_Sex
<<setw(10)<<left<<pNode->m_Post
<<setw(10)<<left<<pNode->m_Department
<<setw(10)<<left<<pNode->m_Wage<<endl;//setw(10)表示占10个字符位置。
pNode=pNode->Next;
}
cout<<"数据文件保存成功!"<<endl;
}





Link Sort(Link Head)
{//我创建的是带头节点的链表。用直接插入法。
if((Head->Next==NULL)||(Head->Next->Next==NULL))//此步条件判断非常有价值。
{
cout<<"数据节点数少于2个,不用排序!"<<endl;
return Head;
}
//-----------第二步;

Link ptr;
Link ptr_F;
Link ptr_N;
ptr=Head->Next->Next;
ptr_F=Head;
Head->Next->Next=NULL;//到此,分成了两个链表。


//第三步。
while(ptr)
{
ptr_N=ptr->Next;
ptr_F=Head;//ptr_F的归位。
while(ptr_F->Next)
{
if(ptr->m_Wage>ptr_F->Next->m_Wage)
{
ptr->Next=ptr_F->Next;
ptr_F->Next=ptr;
break;

}//if
else
{
ptr_F=ptr_F->Next;
}
}//while(ptr_F->Next)
if(ptr_F->Next==NULL)
{
ptr->Next=ptr_F->Next;
ptr_F->Next=ptr;//表示插到有序链表的最后面了。
}

ptr=ptr_N;//归位,准备下一次排序。

}//while(ptr)
cout<<"从高到低,排序成功!"<<endl;
return Head;
}






int main()
{
    Link Head=0;
    Head=Create(Head);
    fstream iofile;
    iofile.open("d:\\iofile.txt",ios_base::in|ios_base::out|ios_base::app);//文件以三种方式打开。
    if(!iofile)
    {
    cout<<"打开文件失败!"<<endl;
    return -1;
    }
    int menu;
    while(1)
    {
    cout<<"*****************************************************"<<endl;
    cout<<"*====================菜单选顶=======================*"<<endl;
    cout<<"*===================================================*"<<endl;
    cout<<"* 1.注册职工 2.修改信息 3.删除信息 4.信息查询 *"<<endl;
    cout<<"* 5.保存文件 6.工资排行 7.信息显示 0.退出系统 *"<<endl;
    cout<<"*****************************************************"<<endl;
    cout<<endl<<"请选择相应操作菜单项:";
    cin>>menu;
    while(cin.fail())
    {
    cout<<"请选择正确的菜单选项。"<<endl;
    cin.clear();
    fflush(stdin);
    cin>>menu;
    }
    switch(menu)
    {
    case 0:
    cout<<"成功退出系统!"<<endl;
    return 0;
    case 1:
    Head=Add(Head);
    break;
    case 2:
    Head=Modify(Head);
    break;
    case 3:
    Head=Del(Head);
    break;
    case 4:
    Search(Head);
    break;
    case 5:
    Save_ByFile(Head,iofile);
    break;
    case 6:
    Sort(Head);
    break;
    case 7:
    Display_List(Head);
    break;
    default:
    cout<<"请选择正确的菜单项进行操作。多谢合作!"<<endl;

    }
    }
    Release(Head);
    iofile.close();
    return 0;
}

//===================
#7
flysky1022008-03-16 20:38
晕,我的题目是c primer第5版第6章的一道题啊,还没到这么复杂的地步吧,
我是自学的。。。。
#8
q1077580892008-03-17 14:17
晕死了。。你跟本就没用循环语句,当然只能输出一个喽。
而且你申请的动态内存也没被释放
#9
flysky1022008-03-17 21:19
可以这样改吗:
# include <iostream>
struct tt
{  char name [20];
    double pace;
};
int main()
{using namespace std;
  tt*jk=new tt;
int i=1;
while(i)
{
  cout<<"请输入姓名:";
  cin.get(jk->name,20);
  cout<<"请输入捐款金额:";
  cin>>jk->pace;
  if(jk->pace>10000)
    cout<<"Grand Patrons:"
        <<jk->name;
    else cout<<"Patrons:"<<jk->name;
  }
  system("pause");
  return 0;
}
#10
kaithwin2008-03-18 10:51
要记录下来,你就用容器么
#11
flysky1022008-03-19 17:23
不懂了呀,我的C++是自学的,身边也没个会的人,遇到问题时除了来这上面来,也没人能帮我了
#12
handongxue2008-03-25 18:46
应该是申请动态结构数组,代码如下:
#include <iostream>
struct tt
{
    char name [20];
    double pace;
};
int main()
{
    using namespace std;
    
    int i=0,count=0;

    cout<<"请输入捐献者数目:count==";
    cin>>count;
    
    tt* jk=new tt[count];

    while(i++<count)
    {
        cout<<"请输入姓名:";
        cin>>jk[i].name;

        cout<<"请输入捐款金额:";
        cin>>jk[i].pace;

    }

    cout<<"Grand Patrons:\n";
    for(i=0;i<count;i++)
        if(jk[i].pace>10000)
            cout<<jk[i].name<<endl;
            

    system("pause");
    return 0;
}
#13
dongfly1112008-03-25 19:06
你用循环了吗
你用循环了吗?不用当然只能输入一个人的了!
#14
elegant872008-03-25 19:54
指针数组
你可以用指针数组来存储你的数据,具体的步骤我也不会,你试试看!
#15
flysky1022008-03-25 20:13
谢谢楼上的,指针数组我也是今天才看到的,由于我自学,还不是很聪明,学的比较慢,指针数组我还没能完全搞透呢
1