版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
算法設(shè)計分析實驗報告專業(yè)班級 軟件工程4班學(xué)號3111006218姓名 陳雪桂授課教師(2014年06月)目錄TOC\o"1-5"\h\z\o"CurrentDocument"一、 實驗?zāi)康?3\o"CurrentDocument"二、 實驗環(huán)境 3\o"CurrentDocument"三、 實驗內(nèi)容 3實驗內(nèi)容 3\o"CurrentDocument"實驗一 3\o"CurrentDocument"實驗二 3\o"CurrentDocument"算法設(shè)計思想 4實驗一 .4\o"CurrentDocument"實驗二 4\o"CurrentDocument"程序設(shè)計 4實驗一 4\o"CurrentDocument"實驗二 10\o"CurrentDocument"數(shù)據(jù)輸入和結(jié)果輸出 12實驗一 12\o"CurrentDocument"實驗二 13\o"CurrentDocument"算法復(fù)雜性分析 13實驗二 13\o"CurrentDocument"四、 實驗心得與小結(jié) 13\o"CurrentDocument"五、 指導(dǎo)教師成績評定 13、實驗?zāi)康恼莆账惴◤?fù)雜性概念。理解影響算法時間復(fù)雜性的因素。理解漸進時間復(fù)雜性的概念。掌握分析算法復(fù)雜度的方法。二、實驗環(huán)境MyEclipse三、實驗內(nèi)容(1)實驗內(nèi)容實驗一理解分治法的效率,用分治法完成快包算法,并給出一個運行實例。實驗二通過鍵盤輸入一個高精度的正整數(shù)n(n的有效位數(shù)<240),去掉其中任意s個數(shù)字后,剩下的數(shù)字按原左右次序?qū)⒔M成一個新的正整數(shù)。編程對給定的n和s,尋找一種方案,使得剩下的數(shù)字組成的新數(shù)最小。【樣例輸入】178543S=4【樣例輸出】13實現(xiàn)該算法,分析算法的效率。并給出一個運行實例:n=“你的學(xué)號”,s=7。算法設(shè)計思想實驗一采用分治法的思想,最最左和最右兩個節(jié)點A、B,分別找到離兩個節(jié)點所在直線兩邊找距離最遠(yuǎn)的兩個點C、D,再遞歸下去直到算法結(jié)束實驗二正整數(shù)序列遍歷,找到第一個a[j]>a[j+1],刪去a[j],重復(fù)s次,也就是刪去s個數(shù)程序設(shè)計實驗/***快包問題**@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());}}//核心函數(shù)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;}}實驗二/*** 通過鍵盤輸入一個高精度的正整數(shù)n(n的有效位數(shù)^240),去掉其中任*******意s個數(shù)字后,剩下的數(shù)字按原左右次序?qū)⒔M成一個新的正整數(shù)。編程對給定的*******【樣例輸入】<br/>178543<br/>S=4<br/>【樣例輸出】<br/>13<br/>*時間效率:O(sn)*空間效率:O(n)**@author陳雪桂**/publicclassDeleteNum{publicstaticvoidmain(String[]args){Scannerscanner=newScanner(System.比);//獲取輸入的要刪樣例System.out.println("請輸入正整數(shù)序列:”);Stringinput=scanner.nextLine();System.out.println("請輸入要刪除的位數(shù):”);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]);}}/***對輸入正整數(shù)序列進行驗證**@paramstr*/publicstaticvoidverifyInput(Stringstr){if(str==null||str==""){thrownewRuntimeException("請輸入要處理的正整數(shù)序列");}for(chars:str.toCharArray()){if(s<'0'||s>'9')thrownewRuntimeException("你輸入的正整數(shù)序列有誤");/****/******處理正整數(shù)序列@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;}}}〃復(fù)制拷貝char[]result=newchar[input.length-s];intindex=0;for(inti=
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 河南省安陽市第二十中學(xué)2022年高三地理下學(xué)期期末試題含解析
- 2025建筑裝修裝飾工程施工合同
- 橋梁場地磚施工合同
- 能源管理精細(xì)化管理技巧
- 咨詢公司客戶資料保密政策
- 教育培訓(xùn)機構(gòu)兼職教師聘用合同
- 陵園綠化項目廢標(biāo)條件研究
- 招投標(biāo)主體法律問題研究
- 藝人經(jīng)紀(jì)承銷協(xié)議書范本
- 商業(yè)秘密保護實施細(xì)則
- 2022年西藏自治區(qū)中考英語真題卷(含答案與解析)
- 醫(yī)院輸血質(zhì)量管理考核標(biāo)準(zhǔn)
- 七年級語文上冊:15、《古代詩歌四首》教案
- 氣道評估與處理課件
- 腦血管病的介入診療課件
- RCS-9626CN電動機保護測控裝置
- 苗木供貨服務(wù)計劃方案
- 回轉(zhuǎn)支承實驗臺測試系統(tǒng)設(shè)計畢業(yè)設(shè)計論文
- 全員安全生產(chǎn)責(zé)任考核表
- 董事長調(diào)研方案
- 危險化學(xué)品MSDS(次氯酸鈉溶液)
評論
0/150
提交評論