资源描述:
《算法贪心算法----活动时间安排》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、詢处矩车工处举院HUBEIUNIVERSITYOFAUTOMOTIVETECHNOLOGY占冬与信息工*峑算法投廿与分析实验报告实验项目实验二实验类别验证性学生姓名王龙学生学号201400797完成日期2016-4-15指导教师刘振章实验成绩评阅日期评阅教师刘振章实验二:贪心算法【实验目的】深入理解贪心法的算法思想,应用贪心算法解决实际的算法问题。【实验性质】验证性实验。【实验要求】有n个活动的集合A二{1,2,..」},其中每个活动都要求使用同一资源,如演讲会场等,而在同一时间内只有一个活动能使用这一资源。求解安排尽量多项活动在该场地进行,即
2、求A的最大相容子集。设待安排的11个活动的开始时间和结束时间按结束时间的升序排列如下:■11234567891011s[i]130535688212f[i]4567891011121314将此表数据作为实现该算法的测试数据。【算法思想及处理过程】实验的算法思想:活动优先安排最早结束的项目,并且要求后一个活动与前一个活动相容,即sjNfi时(j为后一个活动),最后输出安排尽可能多的相容活动。voidinput(inta[][3J):输入时间。通过函数中的for循环输入活动的开始时间和结束时间,并自动续上输入顺序编号。voidsort(intalJ
3、⑶):排序。通过二重for循环对结束时间进行比较,在通过一重for循环交换时间和序号。intgreed(inta[][3],intarr[][ll][3],intm):判断记录被选中的活动时间。本函数是本程序的核心:1、从第M个活动时间开始(利用主函数中的M,M是从0到11),通过for循环和讦语句比较后一个活动的开始时间是否大于前一个活动的结束时间,如果如果大于,则用一个三维数组arr记录下了;然后换到下一个活动时间2、重复第1步,直到最后一个活动为止。【程序代码】#includevoidinput(inta[][3]);〃
4、输入活动时间voidsort(intalJ13J);〃排序voidoutput1(inta[][3]);〃排序的结果输出intgreed(inta[][3],intarr[][ll][3],intm);//判断记录被选中的活动时间voidoutput2(inta[][ll][3],inty,intm);〃输出最大的的活动时间intyi二0;intmain(){intan*ay[l1J[3J;intarr[ll][ll][3]={0J;intz,y,m,b[12J={0};input(array);sort(array);prmtf(,'n)
5、;output1(array);printf(““);for(m=0;m<11;m++)b[m]=greed(array,an;m);y=0;for(m=0;m<11;m++)if(y6、1);for(j=l;j<3;j++)scanf(”%d”,&a[i][j]);voidsort(inta[][3J){inti,j,k,t;for(i=0;i<10;i++)for(j=0;j<10-i;j++)for(k=0;k<3;k++)if(a[j][2]>a[j+l][2]){t=aU][k];aU][k]=aU+l][k];aU+l][k]=t;voidoutput1(inta[]⑶){inti,j;printf("按结束时间的升序排列如下:");for(i=0;i7、时间:H,a[i][0]);for(j=l;j<3;j++)printfC%da[i][j]);printf(un);intgreed(inta[][3],intarr[][ll][3],intm){inti,j,k,y=l;k=a[m][2];//for(i=0;iv3;i++)arr[yi]rO][i]=a[m][i];//for(i=m;i8、put2(inta[][l1][3],inty,intm){inti,j;for(i=0;i