1. 给出结对成员的学号及姓名。

  • 结对成员

    • 031502506 陈龙江
    • 031502529 王国超 click

2.首页给出项目的Github链接。


3. 贴出你们生成的一组最“好”的数据(这里的数据特指 input_data.txt,数据给出对应链接即可),并详细说明"数据生成"程序的原理以及你们所考虑的因素。**

A: 你说input_data怎么生成啊?

B: 不懂啊,随便吧。

A: 了解。

  • 原理:基于随机性原理生成数据

  • 因素:考虑到作业的输入数据的要求:

    • 对于学生而言:

      • 学生数为300人,分成6个班
      • 每名学生有唯一的编号(或者说学号)
      • 每名学生的空闲时间段的有效区间为[8:0020:00]+[1:003:00],空闲时间段个数的有效区间为[2, 15]个
      • 每名学生的部门意愿个数的有效区间为[0, 5],且排在较前面的意愿优先级较高
      • 每名学生的标签个数的有效区间为[2, 20]
    • 对于部门而言:

      • 部门数为20个
      • 每个部门有唯一的编号,格式为D0XX
      • 每个部门的要求学生数上限的有效区间为[10, 15]
      • 每个部门的标签个数的有效区间为[2, 20]
      • 每个部门的常规活动时间段的有效区间为[8:0020:00]+[1:003:00],常规活动时间段个数的有效区间为[2, 15]个
    • 在综合以上因素的限制下,我们采用随机算法生成input_data

    • 将标签限定为:

        string tags[] = {
      "reading", "programming", "film", "English", "reading",
      "music", "dance", "basketball", "chess", "football",
      "swimming", "singing", "climbing", "runing", "drawing",
      "writing", "cooking", "speeching", "piano", "Go"
      };
    • 最“好”的数据,这个“好”是指这一组数据可以得出使得未被分配到学生的部门和未被部门选中的学生的数量尽可能少?还是说这一组数据更加地贴近实际

    • 在我们理解之下,更倾向于使得生成的数据贴近实际,所以我们也倾向于使用随机性的算法来处理。

    • 一个好处是,随机,更贴近实际中不同的学生,不同的部门,可能拥有的无法预测的不同属性的情况。

    • 但明显的不足是,我们所处理的简单的随机,也同时忽略了实际中一个部门所拥有的标签等属性之间的联系、学生的各项属性之间的联系等等情况。这些联系是我们的数据中无法体现出来的,也并不清楚要如何去考虑这些联系。


4.详细说明你们数据建模及匹配程序的思路及实现方式。

  • 数据建模及匹配实现

    • 首先给出Student和Department的定义

        struct Student
      {
      bool isSelect;
      string id;
      vector<pair<int, int> > time;
      vector<string> app;
      vector<string> tags;
      Student() :isSelect(false) {}
      }; struct Department
      {
      int curNum;
      int limit;
      string id;
      vector<pair<int, int> > time;
      vector<string> tags;
      Department():curNum(0){}
      };
    • 以及匹配算法,Match类的主要成员

        class Match
      {
      public:
      Match();
      ~Match();
      void init();
      void stu_dep_matching(const char *infile, const char *outfile, int Pattern = 1);
      private:
      int APP_COEF;
      int TIME_COEF;
      int TAG_COEF;
      Student students[studentNum + 5];
      Department departments[departmentNum + 5];
      string numToTime(int num);
      int timeToNum(string s);
      int getWeekNo(string s);
      pair<int, int> dateToNum(string s);
      void translate(const char *infile);
      vector<Node> matching();
      void writing(vector<Node> &match, const char *outfile);
      };
    • 我们使用jsoncpp来解析和生成json格式的文件

    • 匹配算法大致由3个部分组成:

      1. translate:

        • 解析输入文件,将student和department对应的数据存到students[]和departments[]中
      2. matching:
        • 我们称满足以下情况的学生和部门无法匹配:

          • 学生的意愿中没有相应的部门编号
          • 该学生已经被其他部门接纳
          • 该部门所接纳的学生人数达到上限
        • 在学生和部门可以相互匹配的情况下:
          • 我们给每一对可以相互匹配的学生和部门一个匹配系数match_coef
          • 根据每一对的匹配系数从大到小排序,依次匹配
          • 匹配系数的计算方式为(根据模式的不同(默认意愿优先),意愿系数/时间系数/标签系数也会不同):
              match_coef = 意愿优先级\*意愿系数 + 匹配时间段数\*时间系数 + 匹配标签数\*标签系数
      3. writing:
        • 将第2步得到的匹配情况转化成json格式的output_data文件输出。

5.你们在代码遵循了一定的规范,在博客中描述结对团队遵循的代码规范,并截取部分关键代码佐证说明。

  • 采用面向对象风格的实现,将相应的实现封装成类等等

  • 示例:如Match类,Generator类等等

  • 大括号换行,以下情况除外:

    • if-else语句后只有一行代码
    • 等等
  • 示例:

      int Match::getWeekNo(string s)
    {
    if (!s.compare("Sun")) return 0;
    else if (!s.compare("Mon")) return 1;
    else if (!s.compare("Tues")) return 2;
    else if (!s.compare("Wed")) return 3;
    else if (!s.compare("Thu")) return 4;
    else if (!s.compare("Fri")) return 5;
    else return 6;
    }
  • 命名

    • 函数命名采用驼峰式命名法,第一个单词首字母小写,后面其他单词首字母大写。
    • 变量命名采用驼峰式命名法和下划线命名法结合
    • 类名首字母大写
  • 示例:

      Class Match
    { }; int APP_COEF;
    int TIME_COEF;
    int TAG_COEF; string numToTime(int num);
    int timeToNum(string s);
    int getWeekNo(string s);
    pair<int, int> dateToNum(string s);
  • 等等


6.结果评估。对于程序的匹配结果,你们是否满意?请对你们程序处理结果进行分析。

  • 对于自己生成的input_data文件,程序跑出来有将近1/6的学生无法匹配到相应的部门。
  • 对于生成的随机数据,可以跑出这样的结果还是可以接受的,当然也无法达到满意的程度。
  • 根据输入模式的不同,进行简单的不同属性优先级(如意愿优先/兴趣优先等)的匹配,也可以接受。
  • 但是,作为一个匹配程序,这样的结果说明了它还有很大的提升空间、
  • 输入数据无法预测,我们不可能通过构造一组能使得匹配程序跑出更优结果的数据来提升我们的程序。
  • 那么一个改进的方向是改善匹配的算法:
    • 一是设计更加良好的属性系数的值,使得匹配更合理。
    • 二是更换算法,考虑跑一个网络流之类的进行改进。
  • 除此之外,程序还存在很多的不足,比如:
    • 限定了标签/tags的范围,这对于实际是不行的。一个解决方案是采用hash,利用输入中学生的兴趣标签一定是所有部门特点标签其中的一个这一个条件,生成标签。【undo】
    • 算法的复杂度
    • ...
  • 总而言之,算法的改进空间很大,coding路漫漫...

7.已经尝试过结对编码,你一定很多话要说。请发表结对感受,以及两个人对彼此结对中的闪光点或建议的分享。

  • 首先就是,拖延癌晚期患者,表示对不起对友...
  • 再来就是两个人感觉沟通交流还不是很够吧,结对编码更希望是两个人的同时提升
  • 学习了神奇的jsoncpp
  • 最后加班加点,恰逢家里有事,忙里偷闲的赶完工,还是挺开心的
  • and,在动车上顶着笔记本的最后一点电量写完这篇博客,exciting!

以上。

软件工程实践_结对Task2_ student_department_matching的更多相关文章

  1. 个人作业——软件工程实践总结&个人技术博客

    一. 回望 (1)对比开篇博客你对课程目标和期待,"希望通过实践锻炼,增强软件工程专业的能力和就业竞争力",对比目前的所学所练所得,在哪些方面达到了你的期待和目标,哪些方面还存在哪 ...

  2. memcached vs MySQL Memory engine table 速度比较_XMPP Jabber即时通讯开发实践_百度空间

    memcached vs MySQL Memory engine table 速度比较_XMPP Jabber即时通讯开发实践_百度空间 memcached vs MySQL Memory engin ...

  3. 提高mysql memory(heap) engine内存性能的开源补丁_XMPP Jabber即时通讯开发实践_百度空间

    提高mysql memory(heap) engine内存性能的开源补丁_XMPP Jabber即时通讯开发实践_百度空间 提高mysql memory(heap) engine内存性能的开源补丁

  4. 关于Axure RP软件的介绍——软件工程实践第二次个人作业

    关于Axure RP软件的介绍——软件工程实践第二次个人作业 Axure RP是一个非常专业的快速原型设计的一个工具,客户提出需求,然后根据需求定义和规格.设计功能和界面的专家能够快速创建应用软件或W ...

  5. 集大软件工程15级结对编程week1

    集大软件工程15级结对编程week1 0. 团队成员 姓名 学号 博客园首页 码云主页 孙志威 20152112307 Agt Eurekaaa 孙慧君 201521123098 野原泽君 野原泽君 ...

  6. 福州大学软件工程1816 | W班 第10次作业[软件工程实践总结]

    作业链接 个人作业--软件工程实践总结 评分细则 本次由五个问题(每个十分)+创意照片(五分)+附加题(十分)组成 评分统计图 千帆竞发图 汇总成绩排名链接 汇总链接

  7. BUAA软件工程_结对编程

    1.写在前面 项目 内容 所属课程 2020春季计算机学院软件工程(罗杰 任健) (北航) 作业要求 结对项目作业 课程目标 培养软件开发能力 本作业对实现目标的具体作用 培养结对编程开发项目的能力 ...

  8. BUAA_2020_软件工程_结对项目作业

    项目 内容 这个作业属于哪个课程 班级博客 这个作业的要求在哪里 作业要求 我在这个课程的目标是 掌握软件工程的思路方法 这个作业在哪个具体方面帮助我实现目标 学习结对编程 教学班级 006 项目地址 ...

  9. 《软件工程实践》第五次作业-WordCount进阶需求 (结对第二次)

    在文章开头给出结对同学的博客链接.本作业博客的链接.你所Fork的同名仓库的Github项目地址 本作业博客链接 github pair c 031602136魏璐炜博客 031602139徐明盛博客 ...

随机推荐

  1. visual studio code 在 mac 下按 F12无效

    vsc 默认通过 F12可以查看定义(Go to Definition),可以查看类或方法的定义: 但是在 mac 环境下,有时按 F12并不生效,但是菜单栏的 Go 选项是被启动的,此时需要进行 2 ...

  2. 如何做自己的服务监控?spring boot 1.x服务监控揭秘

    1.准备 下载可运行程序:http://www.mkyong.com/spring-boot/spring-boot-hello-world-example-jsp/ 2.添加服务监控依赖 <d ...

  3. #10 Python字符串

    前言 通过上一节可知,Python6个序列的内置类型中,最常见的是列表和元组,但在Python中,最常用的数据类型却不是列表和元组,而是字符串.要想深入了解字符串,必须先掌握字符编码问题.因此本篇博文 ...

  4. U3D MonoBehaviour

    一.简介 MonoBehaviour是每个脚本派生类的基类,它定义了一个脚本文件从最初被加载到最终被销毁的一个完整过程. 这个过程通过对应的方法体现出来,在不同的方法完成不同的功能,我们把这些方法称为 ...

  5. spring boot整合JMS(ActiveMQ实现)

    pom依赖如下: <?xml version="1.0" encoding="UTF-8"?> <project xmlns="ht ...

  6. hihocoder #1828 : Saving Tang Monk II(BFS)

    描述 <Journey to the West>(also <Monkey>) is one of the Four Great Classical Novels of Chi ...

  7. [Luogu4986] 逃离

    Description 给定次数为 \(n\) 的函数 \(A(x),B(x),C(x)\),求 \(A^2(x)+B^2(x)-C^2(x)\) 在 \([L,R]\) 的零点.\(n\leq 10 ...

  8. Spring之Bean的注入

    Bean的配置中介绍的是Bean声明问题,在哪声明怎么声明的问题.Bean的注入是怎么实例化,怎么注入的问题.Bean注入的方式有两种,一种是在XML中配置,另一种则是使用注解的方式注入. 一.XML ...

  9. nfs 提高传输速度

    通常挂载 nfs 的命令为: mount -t nfs -o nolock 192.168.0.124:/home/admin/rootfs /mnt 之前我一直都是用这个命令来挂载,那个传输速度啊, ...

  10. c# 检测是否有Sql非法字符

    /// <summary> /// 检测是否有Sql危险字符 /// </summary> /// <param name="str">要判断字 ...