第二次结对作业

第六次作业——结对编程第二次

结对情况

自己

  • 327
  • *帅珍

队友

使用语言:C/C++

github作业地址

设计说明

内部实现设计(类图)

匹配算法设计(思想/流程等)

关于算法的原则,最基础的是基于绩点、兴趣、活动时间几点。而单纯的基于其中某点很容易造成结果匹配失衡。因此在经过初步讨论后,我们决定采用兴趣与活动时间相结合的方法。但在进一步讨论后,我们认为学生的部门志愿个数同样对匹配结果有很大影响:志愿少的选择也少,若要使未被部门选中的学生越少越好,那么志愿个数也是个重要参考项。所以最后总结出匹配算法原则为:

  首先设定一优先级T,在部门与学生的匹配过程中,活动时间吻合一条T+4;兴趣标签吻合一条T+2;而部门志愿个数1~5依次对应优先级+5~1;除此之外,我们还考虑到了部门的受欢迎度,将部门按热度排序,热度高的部门优先选择学生。

测试数据如何生成?

在数据生成这一方面,我们选择了手动定义了标签、时间等的随机库数组

- all_tag[20]={"film","ps","ae"···},
- sche_time[6] = { "8:00-10:00","10:00-12:00","14:00-16:00","16:00-18:00","18:00-20:00","20:00-22:00" };

然后通过rand()函数随机确定部门学生标签及其个数[1,5],时间段及其个数[1,3]。此外学生的部门志愿同样随机选择其个数[1,5]。

学生
- 学号
- 兴趣标签
- 标签在标签数组中位置
- 时间
- 时间标签数组中位置
- 部门志愿
- 部门部门数组中位置
部门
- 部门编号
- 限选人数
- 兴趣标签
- 标签在标签数组中位置
- 时间
- 时间标签数组中位置

如何评价自己的匹配算法?

关键代码解释

//统计个部门的意向人数 
for(i=0; i<d_count; i++)
	{
	    for(int j=0; j<s_count; j++)
		{
	    	for(int k=0; k<5; k++){
	    		if(stu[j].de_app_num[k] == (i+1))
				{
	    			worker[i].follow_num++;
	    		}
	    	}
	    }
	}
        
    //对热门/冷门部门排序 
    for(i=0; i<d_count; i++){
        for(int j=i+1; j<d_count; j++)
		{
        	if(worker[i].follow_num < worker[j].follow_num)
			{
        	Departments temp = worker[i];
       		worker[i] = worker[j];
        	worker[j] = temp;
        	}
       	}
    }
        
//进行匹配 
int pp[50][1000][2] = {{{0}}};
for(i=0; i<d_count; i++)
{
    for(int j=0; j<s_count; j++)
	{
	    for(int k=0; k<5; k++)
		{
	    	if(stu[j].de_app_num[k] == (i+1))
			{
	    		for(int m=0; m<5; m++)
				{
	    			for(int n=0; n<5; n++)
					{
	    				if(worker[i].tags_num[m] == stu[j].tags_num[n])
						{
	    					pp[i][j][0] = pp[i][j][0] + 2;
	    				}
	    			}
	    		}
	    		for(int m=0; m<3; m++)
				{
	    			for(int n=0; n<3; n++)
					{
	    				if(worker[i].sched_num[m] == stu[j].sched_num[n])
						{
	    					pp[i][j][0] = pp[i][j][0] + 3;
	    				}
	    			}
	    		}
	    	}
	    }
    }
}
		
//进行筛选
for(i=0; i<d_count; i++)
{
	int j = 0;
   	for(int k=0; k<s_count; k++)
	{
   		if(pp[i][k][1] != 1 && pp[i][k][0] > 0 )
		{
    		int t = k;
    		for(int m=k+1; m<s_count; m++)
			{
   				if(pp[i][m][1] != 1 && pp[i][k][0] > 0 )
				{
   					if(pp[i][k][0] < pp[i][m][0])
					{
   						t = m;
    				}
    			}
    		}
   			pp[i][t][1] = 1;
   			j++;
    	}
    	if(j == worker[i].member_limit)
		{
   			break;
    	}
   	}
	cout<<endl;
}
        
//统计适配分数 
for(i=0; i<d_count; i++)
{
    for(int j=0; j<s_count; j++)
	{
       	cout<<pp[i][j][0]<<":"<<pp[i][j][1]<<" // ";
	}
	cout<<endl;
}

代码规范

函数定义采用驼峰法;缩进规定为四个空格。

关键代码

遇到的困难及解决方法

代码实现时关于部门与学生标签及时间匹配上曾产生过问题:匹配时最暴力的方法就是直接双重循环,但这样就显得十分麻烦。而随机生成的标签及时间可能的重复增加了无用功。在一番讨论后我们决定另外定义数组用于记录随机生成的标签等在随机库中的位置信息,并作为部门、学生信息的一部分输入程序。这样在部门筛选学生时,而这分别持有一标签随机库的位置信息,分别定义数组以0/1表示而这是否有此标签,这样只需要一次循环便可匹配部门学生信息。而且避开了重复标签带来的影响。

有何收获

通过这次作业让我很清楚的体会到了合作的好处。在面对问题时两个人一起讨论使得思考更加全面,分析问题也更加透彻。而且两人在对问题不同看法的思考讨论中,能找到不少新的思路。再者由于代码有两人合作,所以在规范上也必须有意识的配合,个人觉得对养成良好的编码习惯有很大帮助。

对队友的评价

其实这次作业是我第一次接触json格式的数据,因此最初看到题目及输入输出要求时不免有些茫然,事实上如果只有自己一人的话作业完成过程一定非常艰难。而队友在这方面给了我很多帮助,在作业讨论过程中更是提出了不少我没想到的问题,更是在两人合作过程关于作业的核心算法的编写上起主要作用。

PSP表格

PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟)
Planning 计划
· Estimate · 估计这个任务需要多少时间 15 15
Development 开发
· Analysis · 需求分析 (包括学习新技术) 60 90
· Design Spec · 生成设计文档
· Design Review · 设计复审 (和同事审核设计文档)
· Coding Standard · 代码规范 (为目前的开发制定合适的规范) 15 10
· Design · 具体设计 45 60
· Coding · 具体编码 210 240
· Code Review · 代码复审 15 20
· Test · 测试(自我测试,修改代码,提交修改) 30 45
Reporting 报告 45 60
· Test Report · 测试报告
· Size Measurement · 计算工作量
· Postmortem & Process Improvement Plan · 事后总结, 并提出过程改进计划
合计 425 540

学习进度条

第N周 新增代码(行) 累计代码(行) 本周学习消耗时(小时) 累计学习消耗时(小时) 重要成长
110 110 初次接触并使用了原型设计工具,并对NABCD模型有了一定的了解
2/3 340 450 9 15 java学习
4 450 900 13 28 认识并学习了json
原文地址:https://www.cnblogs.com/llsz/p/7674003.html