求C++程序设计

2025-02-24 20:34:34
推荐回答(1个)
回答1:

拿去做下参考,你该下就行了。 # include # include # include #include //用getch(); using namespace std; //﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌Student类﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌ class Student { public: char name[20]; char Id[20]; int Cnum; //C课程得分 int Mnum; //数学课程得分 int Enum; //英语课程得分 int sum; //总分 Student * Next; void Input() { cout<<"\t\t请输入学生的姓名:"; cin>>name; cout<<"\t\t请输入学生的学号:"; cin>>Id; cout<<"\t\t请输入C课程的成绩:"; cin>>Cnum; cout<<"\t\t请输入数学课程的成绩:"; cin>>Mnum; cout<<"\t\t请输入英语课程的成绩:"; cin>>Enum; sum=Cnum+Mnum+Enum; } void ReadFile(istream & in) { in>>name>>Id>>Cnum>>Mnum>>Enum>>sum; } void Show() { cout<<"姓名:"<Next;p!=End;p=p->Next) p->Show(); cout<<"输入任意字符!继续……"; getch(); } void AddItem() { End->Input(); End->Next=new Student; End=End->Next; cout<<"添加成功!"<Next!=End;p=p->Next)//匹配成功则返回上一个指针,不成功就返回空 if(!strcmp(p->Next->name,name))return p; return NULL; } Student *FindID(char * Id) { for(Student * p=Head;p->Next!=End;p=p->Next)//匹配成功则返回上一个指针,不成功就返回空 if(!strcmp(p->Next->Id,Id))return p; return NULL; } }; //﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌构造函数﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌ Studentmassage::Studentmassage() { Head=new Student; Head->Next=new Student; End=Head->Next; in.open("sort.txt"); if(!in) cout<<"这是一个新系统,无学生信息。请先输入。"<ReadFile(in); if(End->name[0]=='\0')break; End->Next=new Student; End=End->Next; } in.close(); cout<<"\t\t读取学生信息成功!"<Next!=End;) { temp=Head->Next; Head->Next=Head->Next->Next; delete temp; } delete Head,End; } //﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌菜单﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌ void Studentmassage::ShowMenu() { cout<<"〓〓〓〓〓〓〓〓〓〓 ☆ 学生成绩管理系 统 ☆ 〓〓〓〓〓〓〓〓〓〓"<>x; switch(x) { case 1:{cout<<"\t\t请输入要查找的学生的姓名:";cin>>name; if(p=FindItem(name)) { p->Next->Show(); cout<<"输入任意字符!继续……"; getch(); } else { cout<<"\t\t没有找到该姓名的学生!"<<'\n'<>Id; if(p=FindID(Id)) { p->Next->Show(); cout<<"输入任意字符!继续……"; getch(); } else { cout<<"\t\t没有找到该学好的学生!"<<'\n'<>name; if(p=FindItem(name)) { cout<<"\t\t已找到学生的信息,请输入新的信息!"<Next->Input(); cout<<"修改成功!"<>name; if(p=FindItem(name)) { temp=p->Next; p->Next=p->Next->Next; delete temp; cout<<"\t\t删除成功!"<name,p1->name); strcpy(temp->Id,p1->Id); temp->Cnum=p1->Cnum; temp->Mnum=p1->Mnum; temp->Enum=p1->Enum; temp->sum=p1->sum; strcpy(p1->name,p2->name); strcpy(p1->Id,p2->Id); p1->Cnum=p2->Cnum; p1->Mnum=p2->Mnum; p1->Enum=p2->Enum; p1->sum=p2->sum; strcpy(p2->name,temp->name); strcpy(p2->Id,temp->Id); p2->Cnum=temp->Cnum; p2->Mnum=temp->Mnum; p2->Enum=temp->Enum; p2->sum=temp->sum; } //﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌ int Studentmassage::ListCount()//统计当前链表的记录总数,返回一个整数 { if(! Head) return 0; int n=0; for(Student * p=Head->Next;p!=End;p=p->Next) { n++; } return n; } //﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌ void Studentmassage::Sort()//对当前链表进行排序 { cout <<"Sorting..."<Next;p!=End;p=p->Next) for(k=p->Next;k!=End;k=k->Next) { if(p->sum>k->sum) { Studentmassage::Swap(p,k); } } cout <<"排序完成!"<Next;p!=End;p=p->Next) out<name<<"\t"<Id<<"\t"<Cnum<<"\t" <Mnum<<"\t"<Enum<<"\t"<sum<<'\n'; out.close(); } //﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌主函数﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌﹌ int main() { int x,i=0; bool quit=false; cout<<"\t\t§§§§§§§§§§§§§§§§§§§§§§§§§§"<>x; switch(x) { case 0:quit=true;break; case 1:Grade.AddItem();break; case 2:Grade.Display();break; case 3:Grade.Sort();break; case 4:Grade.Find();break; case 5:Grade.RemoveItem();break; case 6:Grade.ModifyItem();break; } } return 0; } 第二个 //Query.cpp #include #include #include #include #include #include #include #include"TextQuery.h" using namespace std; void print_results(const set &locs,const string &sought,const TextQuery &file) { typedef set line_nums; line_nums::size_type size=locs.size(); cout<>s; if(s=="-quit") break; set locs= tq.run_query(s); print_results(locs,s,tq); } } else cerr<<"当前目录下没有1.txt文件或其他读取错误!"<::size_type line_no; void read_file(std::ifstream &is) {store_file(is);build_map();} std::set run_query(const std::string&) const; std::string text_line(line_no) const; private: void store_file(std::ifstream&); void build_map(); std::vector lines_of_text; std::map< std::string,std::set > word_map; }; void TextQuery::store_file(std::ifstream &is) { string textline; while(getline(is,textline)) lines_of_text.push_back(textline); } void TextQuery::build_map() { for(line_no line_num=0;line_num!=lines_of_text.size();++line_num){ istringstream line(lines_of_text[line_num]);//inclue string word; while(line>>word) word_map[word].insert(line_num); } } set TextQuery::run_query(const std::string &query_word) const{ map >::const_iterator loc=word_map.find(query_word); if(loc==word_map.end()) return set(); else return loc->second; } std::string TextQuery::text_line(TextQuery::line_no line) const{ if(line
记得采纳啊