java第五次上機實驗_第1頁
java第五次上機實驗_第2頁
java第五次上機實驗_第3頁
java第五次上機實驗_第4頁
java第五次上機實驗_第5頁
已閱讀5頁,還剩4頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

java第五次上機實驗java第五次上機實驗/1/3java第五次上機實驗Java第五次上機實驗一、定義一個接口Shape,其中包括一個抽象方法area(),設(shè)計矩形/圓/三角形等類實現(xiàn)Shape接口。分別創(chuàng)建代表矩形/圓/三角形的3個對象存入一個Shape類型的數(shù)組中,通過調(diào)用area()方法將數(shù)組中各類圖形的面積輸出。實驗代碼:interfaceShape{ doublearea();}classRectangleimplementsShape{ doublea,b; Rectangle(doublea,doubleb){ this.a=a; this.b=b; } publicdoublearea(){ returna*b; }}classCircleimplementsShape{ doubler; Circle(doubler){ this.r=r; } publicdoublearea(){ return3.14*r*r; }}classTriangleimplementsShape{ doublea,b,c; Triangle(doublea,doubleb,doublec){ this.a=a; this.b=b; this.c=c; } publicdoublearea(){ doublet=(a+b+c)/2; returnMath.sqrt((t-a)*(t-b)*(t-c)*t); }}publicclassProject1{ /** *@paramargs */ publicstaticvoidmain(String[]args){ //TODOAuto-generatedmethodstub Shapea[]=newShape[3]; a[0]=newRectangle(2,3); System.out.println("矩形的面積:"+a[0].area()); a[1]=newCircle(2); System.out.println("圓面積:"+a[1].area()); a[2]=newTriangle(3,4,5); System.out.println("三角形面積:"+a[2].area()); }}實驗結(jié)果:二、2創(chuàng)建一個有理數(shù)的計算器:實現(xiàn)時:javaEx3/4+1/53/4+1/5=19/20javaEx3/4-1/53/4-1/5=11/20javaEx3/4*1/53/4*1/5=3/20 程序從命令行得到三個參數(shù)(操作數(shù)1,操作符,操作數(shù)2),顯示該表達式以及算數(shù)運算的結(jié)果。 提示:使用String類的split方法來獲取分子字符串和分母字符串,并使Integer.parseInt方法將字符串轉(zhuǎn)換為整數(shù)。實驗代碼:publicclassEx{ /** *@paramargs */ publicstaticvoidmain(String[]args){ //TODOAuto-generatedmethodstub StringNumber[]=args[0].split("\\D+");//讀取數(shù)值 intsum1=0; intsum2=0; //for(inti=0;i<Number.length;i++) //System.out.println(Number[i]); if(args[0].contains("+")){ sum1+=Integer.parseInt(Number[0])*Integer.parseInt(Number[3])+Integer.parseInt(Number[2])*Integer.parseInt(Number[1]); sum2+=Integer.parseInt(Number[1])*Integer.parseInt(Number[3]); } elseif(args[0].contains("-")){ sum1+=Integer.parseInt(Number[0])*Integer.parseInt(Number[3])-Integer.parseInt(Number[2])*Integer.parseInt(Number[1]); sum2+=Integer.parseInt(Number[1])*Integer.parseInt(Number[3]); } elseif(args[0].contains("*")){ sum1+=Integer.parseInt(Number[0])*Integer.parseInt(Number[2]); sum2+=Integer.parseInt(Number[1])*Integer.parseInt(Number[3]); } System.out.println(args[0]+"="+sum1+"/"+sum2); }}運行結(jié)果:三、 設(shè)計一個名為Geometry的抽象類,其中有名為getArea()的抽象方法,getPerimeter的抽象方法 設(shè)計一個名為Square的類,繼承Geometry類,重寫兩個抽象方法;創(chuàng)建含有2個元素的Geometry類的數(shù)組,第一個元素為Square類的對象,第二個元素如下:以匿名類的形式創(chuàng)建一個模擬Circle類的對象,繼承Geometry類,重寫兩個抽象方法;打印每個對象的面積,周長。實驗代碼:abstractclassGeometry{ abstractdoublegetArea(); abstractdoublegetPerimeter();}classSquareextendsGeometry{ doublea; Square(doublea){ this.a=a; } doublegetArea(){//面積 returna*a; } doublegetPerimeter(){//周長 return4*a; } }publicclassProject3{ publicstaticvoidmain(String[]args){ //TODOAuto-generatedmethodstub Geometrya[]=newGeometry[2]; a[0]=newSquare(4); System.out.println("正方形面積和周長為:"+a[0].getArea()+","+a[0].getPerimeter()); a[1]=newGeometry(){ doubler=1; doublegetArea(){ return3.14*r*r; } doublegetPerimeter(){ return3.14*r*2; } }; System.out.println("圓面積和周長為:"+a[1].getArea()+","+a[1].getPerimeter()); }}運行結(jié)果:四、編寫一個方法,求整數(shù)矩陣中特定列的所有元素的和,使用下面的方法頭:publicstaticdoublesumColumn(double[][]m,intcolumnIndex)編寫一個測試程序,讀取一個3*4的矩陣,然后顯示每列元素的和。實驗代碼:importjava.util.Scanner;classArray{ publicstaticdoublesumColumn(doublem[][],intcolumnIndex){ //????????columnIndex???????? doublesum=0; intj=columnIndex-1; for(inti=0;i<3;i++) sum+=m[i][j]; returnsum; }}publicclassProject4{ /** *@paramargs */ publicstaticvoidmain(String[]args){ //TODOAuto-generatedmethodstub double[][]m=newdouble[3][4]; System.out.println("輸入3*4矩陣:"); Scannerreader=newScanner(System.in); for(inti=0;i<3;i++) for(intj=0;j<4;j++) { //m[i][j]=2.0;// m[i][j]=reader.nextDouble(); } Arraya=newArray(); System.out.println("矩陣第一列元素之和:"+a.sumColumn(m,1)); }}運行結(jié)果:五、編寫兩個矩陣相乘的方法。方法頭如下:publicstaticdouble[][]multiplyMatrix(double[][]a,double[][]b)編寫程序進行測試。實驗代碼:importjava.util.Scanner;classArray{ publicstaticdouble[][]multiplyMatrix(double[][]a,double[][]b){ doubletemp[][]=newdouble[3][3]; doublesum=0; for(inti=0;i<3;i++){ for(intj=0;j<3;j++){ sum=0; for(intp=0;p<3;p++) sum+=a[i][p]*b[p][j]; temp[i][j]=sum; } } returntemp; }}publicclassProject5{ /** *@paramargs */ publicstaticvoidmain(String[]args){ //TODOAuto-generatedmethodstub doublea[][]=newdouble[3][3]; doubleb[][]=newdouble[3][3]; doublec[][]=newdouble[3][3]; Scannerreader=newScanner(System.in); System.out.println("輸入矩陣a:"); for(inti=0;i<3;i++) for(intj=0;j<3;j++){ a[i][j]=reader.nextDouble(); } System.out.println("輸入矩陣b:"); for(inti=0;i<3;i++)

溫馨提示

  • 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)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論