当前位置: 首页 > news >正文

c++实验六

实验任务一:

 1 #include <algorithm>
 2 #include <iostream>
 3 #include <stdexcept>
 4 #include <vector>
 5 #include "contestant.hpp"
 6 #include "utils.hpp"
 7 
 8 const std::string in_file = R"(C:\Users\zhang\Downloads\实验6部分代码及数据文件_gbk\实验6部分代码及数据文件_gbk\1\data.txt)";
 9 const std::string out_file = "./ans.txt";
10 
11 void app() {
12     std::vector<Contestant> contestants;
13 
14     try {
15         contestants = load(in_file);                                      
16         std::sort(contestants.begin(), contestants.end(), cmp_by_solve); 
17         print(contestants);      
18         save(out_file, contestants);                         
19     } catch (const std::exception& e) {
20         std::cerr << e.what() << '\n';
21         return;
22     }
23 }
24 
25 int main() {
26     app();
27 }
task1.cpp
 1 #include <algorithm>
 2 #include <iostream>
 3 #include <stdexcept>
 4 #include <vector>
 5 #include "contestant.hpp"
 6 #include "utils.hpp"
 7 
 8 const std::string in_file = R"(C:\Users\zhang\Downloads\实验6部分代码及数据文件_gbk\实验6部分代码及数据文件_gbk\1\data.txt)";
 9 const std::string out_file = "./ans.txt";
10 
11 void app() {
12     std::vector<Contestant> contestants;
13 
14     try {
15         contestants = load(in_file);                                      
16         std::sort(contestants.begin(), contestants.end(), cmp_by_solve); 
17         print(contestants);      
18         save(out_file, contestants);                         
19     } catch (const std::exception& e) {
20         std::cerr << e.what() << '\n';
21         return;
22     }
23 }
24 
25 int main() {
26     app();
27 }
contestant.hpp
 1 #pragma once
 2 #include <fstream>
 3 #include <iostream>
 4 #include <stdexcept>
 5 #include <string>
 6 #include <vector>
 7 #include "contestant.hpp"
 8 
 9 // ACM 排序规则:先按解题数降序,再按罚时升序
10 inline bool cmp_by_solve(const Contestant& a, const Contestant& b) {
11     if(a.solved != b.solved)
12         return a.solved > b.solved;
13     
14     return a.penalty < b.penalty;
15 }
16 
17 // 将结果写至任意输出流
18 inline void write(std::ostream& os, const std::vector<Contestant>& v) {
19     for (const auto& x : v) 
20         os << x << '\n';
21 }
22 
23 // 将结果打印到屏幕
24 inline void print(const std::vector<Contestant>& v) {
25     write(std::cout, v);
26 }
27 
28 // 将结果保存到文件
29 inline void save(const std::string& filename, const std::vector<Contestant>& v) {
30     std::ofstream os(filename);
31     if (!os) 
32         throw std::runtime_error("fail to open " + filename);
33 
34     write(os, v);
35 }
36 
37 // 从文件读取信息(跳过标题行)
38 inline std::vector<Contestant> load(const std::string& filename) {
39     std::ifstream is(filename);
40     if (!is) 
41         throw std::runtime_error("fail to open " + filename);
42 
43     std::string line;
44     std::getline(is, line);          // 跳过标题
45 
46     std::vector<Contestant> v;
47     Contestant t;
48     int seq;
49     while (is >> seq >> t) 
50         v.push_back(t);
51         
52     return v;
53 }
utils.hpp

问题1:

  答:(1)根据类型兼容规则,ostream是ofstream的基类,所以可以接受std::ostream的实参,当然也可以接受本就是ostream类的对象std::cout。

    (2)不需要了。

问题2:

 答:(1)无法打开文件时抛出异常。

   (2)异常被std::exception &e 捕捉了。

     处理:输出了错误类型,并接结束了程序的运行。

问题3:

  答:是可行的。功能性能结果一致。

问题4:

  答:第二三行之间的空行对读取没有影响,cin会自动跳过,但是第七行数据的解题数和总罚时数据空缺,因此顺延读到了下一行数据的序列和学号,因此导致了后面数据的读取混乱。

 

 

image

 实验任务二:

  答:(类的实现直接写在了hpp文件里面)

 1 #include <iostream>
 2 #include <limits>
 3 #include <string>
 4 #include "stumgr.hpp"
 5 
 6 const std::string in_file = "./data_bad.txt";
 7 const std::string out_file = "./ans_bad.txt";
 8 
 9 void menu() {
10     std::cout << "\n**********简易应用**********\n"
11                  "1. 加载文件\n"
12                  "2. 排序\n"
13                  "3. 打印到屏幕\n"
14                  "4. 保存到文件\n"
15                  "5. 退出\n"
16                  "请选择:";
17 }
18 
19 void app() {
20     StuMgr mgr;
21 
22     while(true) {
23         menu();
24         int choice;
25         std::cin >> choice;
26 
27         try {
28             switch (choice) {
29             case 1: mgr.load(in_file); 
30                     std::cout << "加载成功\n"; break;
31             case 2: mgr.sort(); 
32                     std::cout << "排序已完成\n"; break;
33             case 3: mgr.print(); 
34                     std::cout << "打印已完成\n"; break;
35             case 4: mgr.save(out_file); 
36                     std::cout << "导出成功\n"; break;
37             case 5: return;
38             default: std::cout << "不合法输入\n";
39             }
40         }
41         catch (const std::exception& e) {
42             std::cout << "Error: " << e.what() << '\n';
43         }
44     }
45 }
46 
47 int main() {
48     app();
49 }
student.hpp
 1 #pragma once
 2 #include <string>
 3 #include<fstream>
 4 #include <vector>
 5 #include<algorithm>
 6 #include "student.hpp"
 7 class StuMgr {
 8 public:
 9     void load(const std::string& file);  // 加载数据文件(空格分隔)
10     void sort();                         // 排序: 按专业字典序升序、同专业分数降序
11     void print() const;                  // 打印到屏幕
12     void save(const std::string& file) const; // 保存到文件
13 
14 private:
15     void write(std::ostream &os) const;  // 把数据写到任意输出流
16 
17 private:
18     std::vector<Student> students;
19 };
20 
21 void StuMgr::load(const std::string& file)// 加载数据文件(空格分隔)
22 {
23     std::ifstream inf;
24     std::string temp;
25     Student u;
26     inf.open(file);
27     if (!inf)
28         throw std::runtime_error("cannot open file: " + file);
29     std::getline(inf, temp, '\n');
30     while (inf >> u)
31     {
32         students.push_back(u);
33     }
34 }
35 
36 void StuMgr::sort()             // 排序: 按专业字典序升序、同专业分数降序
37 {
38     std::sort(students.begin(), students.end(), [](Student& a, Student& b)->bool {if (a.get_grade() != b.get_grade())return a.get_grade() > b.get_grade(); else return a.get_name() > a.get_name(); });
39 }
40 
41 void StuMgr::print() const    // 打印到屏幕
42 {
43     
44     for (auto item : students)
45         cout << item ;
46 }
47 
48 void StuMgr::write(std::ostream& os) const // 把数据写到任意输出流
49 {
50     for (auto item : students)
51         os << item;
52 }
53 
54 
55 void StuMgr::save(const std::string& file) const        // 保存到文件
56 {
57     std::ofstream outf;
58     outf.open("./ans",std::ios::out);
59     if (!outf)
60         throw std::runtime_error("cannot open file: " + file);
61 
62     write(outf);
63 }
stumgr.hpp
 1 #include <iostream>
 2 #include <limits>
 3 #include <string>
 4 #include "stumgr.hpp"
 5 
 6 const std::string in_file = "./data_bad.txt";
 7 const std::string out_file = "./ans_bad.txt";
 8 
 9 void menu() {
10     std::cout << "\n**********简易应用**********\n"
11                  "1. 加载文件\n"
12                  "2. 排序\n"
13                  "3. 打印到屏幕\n"
14                  "4. 保存到文件\n"
15                  "5. 退出\n"
16                  "请选择:";
17 }
18 
19 void app() {
20     StuMgr mgr;
21 
22     while(true) {
23         menu();
24         int choice;
25         std::cin >> choice;
26 
27         try {
28             switch (choice) {
29             case 1: mgr.load(in_file); 
30                     std::cout << "加载成功\n"; break;
31             case 2: mgr.sort(); 
32                     std::cout << "排序已完成\n"; break;
33             case 3: mgr.print(); 
34                     std::cout << "打印已完成\n"; break;
35             case 4: mgr.save(out_file); 
36                     std::cout << "导出成功\n"; break;
37             case 5: return;
38             default: std::cout << "不合法输入\n";
39             }
40         }
41         catch (const std::exception& e) {
42             std::cout << "Error: " << e.what() << '\n';
43         }
44     }
45 }
46 
47 int main() {
48     app();
49 }
task2.cpp
 1 学号    姓名    专业    成绩
 2 1001    抖森    Acting    80
 3 1002    宝爷    Music    97
 4 1003    大眼仔    Acting    75
 5 1004    本喵    Acting    99
 6 1005    裘花    Acting    89
 7 1006    小李子    Acting    92
 8 1007    无脸男    Acting    85
 9 1008    甜茶    Acting    91
10 1009    囧瑟夫    Acting    88
11 1010    霉霉    Music    96
data.txt
 1 学号    姓名    专业    成绩
 2 1001    抖森    Acting    80
 3 1002    宝爷    Music    97
 4 1003    大眼仔    Acting    
 5 1004    本喵    Acting    99
 6 1005    裘花    Acting    89
 7 1006    小李子    Acting    92
 8 1007    无脸男    Acting    105
 9 1008    甜茶    Acting    91
10 1009    囧瑟夫    Acting    88
11 1010    霉霉    Music    96
data_bad.txt

屏幕截图 2025-12-19 164148

 

image

 

http://www.gsyq.cn/news/124719.html

相关文章:

  • 2025年中压电缆优质厂家权威推荐榜单:防火电缆/电线电缆/控制电缆源头厂家精选 - 品牌推荐官
  • 2025年数控激光切割机定做厂家权威推荐榜单:小型激光切割机/激光切割设备/管材激光切割机源头厂家精选 - 品牌推荐官
  • 实用指南:企业级部署升级:Nginx 反向代理 + ELK 日志监控,让成绩预测平台稳定可追溯
  • 2025年除冰剂供货厂家推荐榜单:除冰融雪剂/融雪设备/氯化钠融雪剂源头厂家精选 - 品牌推荐官
  • 解决Docker磁盘空间告急:认识并清理“悬空镜像”
  • 日本股票 API 对接实战指南(实时行情与 IPO 专题)
  • 2025年12月拉力机与冲片机厂家权威推荐榜:电子/电脑/双柱/橡胶/线材/薄膜拉力机,手动/气动/电动冲片机,精准耐用工业之选 - 品牌企业推荐师(官方)
  • 前端工程化体系深度设计
  • 邮件网关哪个好?2025邮件网关产品推荐 - U-Mail邮件系统
  • 《lvgl基础学习 —— lv_style》
  • 实战两台 Windows 电脑互联传输文件
  • 2025年行业内诚信的制冷设备生产厂家推荐榜,冷却塔/方形逆流冷却塔/工业冷却塔/冷却水塔/冷却塔填料/圆形逆流冷却塔制冷设备公司联系电话 - 品牌推荐师
  • 想刷到特价机票?2025这些平台容易遇到低价,也省心! - 资讯焦点
  • 2025年12月滨海新区装修公司排名top5:佰瑞佳垄断高端别墅大平层装修市场 - 品牌智鉴榜
  • redis-ai
  • 完整教程:电脑硬件解剖,拆解主流机型,分享硬件升级与故障排查经验
  • 2025-2026权威盘点:靠谱的国际博士报读渠道8大口碑好的国际博士服务商深度测评 - 阿喂嘞lvv
  • 2025年高活性NMN品牌推荐与市场动态,NMN年度报告榜单,口服品牌评测 - 资讯焦点
  • 视频融合平台EasyCVR构建新能源充电桩可视化监控服务方案
  • 2025年充电桩厂家推荐:汽车、重卡、大车、直流、大功率、商用、快速充电桩厂家选择指南 - 深度智识库
  • 【2025最新】掌上看家采集端下载安装教程详解:全平台配置实践与性能优化指南 - PC修复电脑医生
  • 2025医用病房门品牌推荐:六家国产医疗级防护门企业核心技术优势深度解析 - 品牌企业推荐师(官方)
  • 不止是电话!如何通过技术与服务甄选靠谱的腾讯企业邮箱代理商 - 品牌2026
  • 上海企业微信代理商:传统VS新兴,谁更懂中小企业需求? - 品牌2026
  • 一些检索论文的工具
  • 【赵渝强老师】MySQL集群解决方案
  • 2025年杭州小程序开发公司权威推荐榜单:app开发/官网建设/小程序搭建源头公司精选 - 品牌推荐官
  • 重磅!2025年中国充电桩源头厂家年度十大品牌竞争力深度解析 - 深度智识库
  • 2025年叶片式定量灌装机十大品牌权威推荐,市场上定量灌装机生产厂家口碑排行甄选实力品牌 - 品牌推荐师
  • 2026在职读研必看:国际在职研究生教育咨询机构七大靠谱国际在职硕士博士申请辅导机构深度测评指南 - 阿喂嘞lvv