版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
算法设计分析实验报告专业班级 软件工程4班学号3111006218姓名 陈雪桂授课教师(2014年06月)目录TOC\o"1-5"\h\z\o"CurrentDocument"一、 实验目的 3\o"CurrentDocument"二、 实验环境 3\o"CurrentDocument"三、 实验内容 3实验内容 3\o"CurrentDocument"实验一 3\o"CurrentDocument"实验二 3\o"CurrentDocument"算法设计思想 4实验一 .4\o"CurrentDocument"实验二 4\o"CurrentDocument"程序设计 4实验一 4\o"CurrentDocument"实验二 10\o"CurrentDocument"数据输入和结果输出 12实验一 12\o"CurrentDocument"实验二 13\o"CurrentDocument"算法复杂性分析 13实验二 13\o"CurrentDocument"四、 实验心得与小结 13\o"CurrentDocument"五、 指导教师成绩评定 13、实验目的掌握算法复杂性概念。理解影响算法时间复杂性的因素。理解渐进时间复杂性的概念。掌握分析算法复杂度的方法。二、实验环境MyEclipse三、实验内容(1)实验内容实验一理解分治法的效率,用分治法完成快包算法,并给出一个运行实例。实验二通过键盘输入一个高精度的正整数n(n的有效位数<240),去掉其中任意s个数字后,剩下的数字按原左右次序将组成一个新的正整数。编程对给定的n和s,寻找一种方案,使得剩下的数字组成的新数最小。【样例输入】178543S=4【样例输出】13实现该算法,分析算法的效率。并给出一个运行实例:n=“你的学号”,s=7。算法设计思想实验一采用分治法的思想,最最左和最右两个节点A、B,分别找到离两个节点所在直线两边找距离最远的两个点C、D,再递归下去直到算法结束实验二正整数序列遍历,找到第一个a[j]>a[j+1],删去a[j],重复s次,也就是删去s个数程序设计实验/***快包问题**@author陈雪桂**/publicclassQuickPackage{staticList<Dian>pack=newArrayList<Dian>();publicstaticvoidmain(String[]args)List<Dian>list=newArrayList<Dian>();list.add(newDian(2.3,12.2));list.add(newDian(3.6,29.0));list.add(newDian(15.4,2.4));list.add(newDian(18.4,34.2));list.add(newDian(14.2,15.5));list.add(newDian(17.1,37.9));list.add(newDian(23.1,18.2));list.add(newDian(14.2,34.1));list.add(newDian(30.2,45.8));list.add(newDian(38.6,22.4));list.add(newDian(48.6,32.4));list.add(newDian(18.6,22.4));list.add(newDian(78.6,62.4));list.add(newDian(23.3,39.0));list.add(newDian(13.9,43.0));list.add(newDian(133.3,234.0));DianleftDian=list.get(0);DianrightDian=list.get(0);for(Diandian:list){if(dian.getX()<leftDian.getX())leftDian=dian;elseif(dian.getX()>rightDian.getX())rightDian=dian;}pick.add(leftDian);pick.add(rightDian);QuickPackagep=newQuickPackage();Dian[]dians=newDian[list.size()];list.toArray(dians);System.out.println(leftDian.getX()+ ":" +leftDian.getY());System.out.println(rightDian.getX()+ ":" +rightDian.getY());Map<String,Dian[]>map=p.separate(dians,leftDian,rightDian);Dian[]left=map.get("left");Dian[]right=map.get("right");p.package1(left,leftDian,rightDian);p.package1(right,rightDian,leftDian);for(Diandian:pack){System.out.println("X:"+dian.getX()+""+"Y:"+dian.getY());}}//核心函数publicvoidpackage1(Dian[]dians,Diandian1,Diandian2){if(dians.length==2)return;if(dians.length==3){for(Diandian:dians){if(!dian.equals(dian1)&&!dian.equals(dian2)){pack.add(dian);}}return;}DianmaxDian=this.maxlength(dians,dian1,dian2);pack.add(maxDian);Map<String,Dian[]>map1=this.separate(dians,dian1,maxDian);Dian[]right=map1.get("right");Map<String,Dian[]>map2=this.separate(right,maxDian,dian2);this.package1(map1.get("left"),dian1,maxDian);this.package1(map2.get("left"),maxDian,dian2);/***将点分为在直线左和在直线右边*@paramdians@paramdianl@paramdian2@return*/publicMap<String,Dian[]>separate(Dian[]dians,Diandianl,Diandian2){List<Dian>left=newArrayList<>();List<Dian>right=newArrayList<>();for(Diandian:dians){doubler=dian1.getX()*dian2.getY()+dian.getX()*dian1.getY()+dian2.getX()*dian.getY()-dian.getX()*dian2.getY()-dian2.getX()*dian1.getY()-dian1.getX()*dian.getY();if(r>1E-8)left.add(dian);elseif(r<1E-8&&r>-1E-8){left.add(dian);right.add(dian);}elseright.add(dian);}Dian[]leftDians=newDian[left.size()];Dian[]rightDians=newDian[right.size()];left.toArray(leftDians);right.toArray(rightDians);left=null;right=null;
Map<String,Dian[]>map=newTreeMap<String,Dian[]>();map.put("left”,leftDians);map.put("right”,rightDians);returnmap;}/***/****点集合中的点到dian1、dian2直线的距离@paramdians@paramdian1@paramdian2@return*/publicDianmaxlength(Dian[]dians,Diandian1,Diandian2){doubleA=(dian2.getY()-dian1.getY())/(dian2.getX()-dian1.getX());doubleB=-1;doubleC=dian2.getY()-((dian2.getY()-dian1.getY())/(dian2.getX()-dian1.getX()))*dian2.getX();doublemaxlength=0;DianmaxDian=null;for(Diandian:dians){if(lengthToLine(dian,A,B,C)>maxlength){maxlength=lengthToLine(dian,A,B,C);maxDian=dian;}returnmaxDian;}/***点到直线的距离*@paramdian@paramA@paramB@paramC@return*/publicdoublelengthToLine(Diandian,doubleA,doubleB,doubleC){doublei=((A*dian.getX()+B*dian.getY()+C)/Math.sqrt(A*A+B*B));returni>0?i:-i;}}classDian{doublex;doubley;publicDian(){}publicDian(doublex,doubley){this.x=x;this.y=y;}publicdoublegetX(){returnx;}publicvoidsetX(doublex){this.x=x;}publicdoublegetY()
returny;}publicvoidsetY(doubley){this.y=y;}}实验二/*** 通过键盘输入一个高精度的正整数n(n的有效位数^240),去掉其中任*******意s个数字后,剩下的数字按原左右次序将组成一个新的正整数。编程对给定的*******【样例输入】<br/>178543<br/>S=4<br/>【样例输出】<br/>13<br/>*时间效率:O(sn)*空间效率:O(n)**@author陈雪桂**/publicclassDeleteNum{publicstaticvoidmain(String[]args){Scannerscanner=newScanner(System.比);//获取输入的要删样例System.out.println("请输入正整数序列:”);Stringinput=scanner.nextLine();System.out.println("请输入要删除的位数:”);ints=scanner.nextInt();
verifyInput(input);char[]result=handle(input.toCharArray(),s);System.out.print("处理后的序列是:");for(inti=0;i<result.length;i++){System.out.print(result[i]);}}/***对输入正整数序列进行验证**@paramstr*/publicstaticvoidverifyInput(Stringstr){if(str==null||str==""){thrownewRuntimeException("请输入要处理的正整数序列");}for(chars:str.toCharArray()){if(s<'0'||s>'9')thrownewRuntimeException("你输入的正整数序列有误");/****/******处理正整数序列@paraminput@return*/publicstaticchar[]handle(char[]input,ints){for(inti=0;i<s;i++){for(intj=0;j<input.length-1;j++){if(input[j]>input[j+1]){input[j]='#';break;}}}〃复制拷贝char[]result=newchar[input.length-s];intindex=0;for(inti=
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年度绿色金融创新产品开发贷款合同3篇
- 2024质保协议书范本
- 2024葡萄品种专项销售代理协议版B版
- 2024跨区域连锁加盟门店承包合同
- 2024版最正式的借款合同
- 二零二五年度电商绿色物流合作协议3篇
- 2024软件许可合同 with 软件功能与技术支持服务
- 二零二五年度陕西省旅游项目开发合作合同2篇
- 西安文理学院《汽车试验技术及性能试验》2023-2024学年第一学期期末试卷
- 2025年度国际贸易供应链合同解析3篇
- 手机归属地表格
- GB/T 24479-2023火灾情况下的电梯特性
- 鼻空肠管的护理
- ICH Q3D元素杂质指导原则
- 五年级解方程计算题100道
- 汉语教学 《成功之路+进步篇+2》第16课课件
- GB/T 20028-2005硫化橡胶或热塑性橡胶应用阿累尼乌斯图推算寿命和最高使用温度
- 广州新版四年级英语下册-复习计划
- 小学语文三年级下册生字偏旁、拼音、组词
- 2022年宁波开发投资集团有限公司招聘笔试题库及答案解析
- 论财务共享服务模式下财务稽核体系
评论
0/150
提交评论