50编程题及答案
【程序1】??? 題目:古典問題:有一對兔子,從出生后第3個月起每個月都生一對兔子,小兔子長到第三個月后每個月又生一對兔子,假如兔子都不死,問每個月的兔子總數為多少???? //這是一個菲波拉契數列問題 public class lianxi01 { public static void main(String[] args) { System.out.println("第1個月的兔子對數:??? 1"); System.out.println("第2個月的兔子對數:??? 1"); int f1 = 1, f2 = 1, f, M=24; ???? for(int i=3; i<=M; i++) { ????? f = f2; ????? f2 = f1 + f2; ????? f1 = f; ????? System.out.println("第" + i +"個月的兔子對數: "+f2); ???????? } } }
【程序2】??? 題目:判斷101-200之間有多少個素數,并輸出所有素數。 程序分析:判斷素數的方法:用一個數分別去除2到sqrt(這個數),如果能被整除, 則表明此數不是素數,反之是素數。??? public class lianxi02 { public static void main(String[] args) { ??? int count = 0; ??? for(int i=101; i<200; i+=2) { ???? boolean b = false; ???? for(int j=2; j<=Math.sqrt(i); j++) ???? { ??????? if(i % j == 0) { b = false; break; } ???????? else?????????? ?{ b = true; } ???? } ??????? if(b == true) {count ++;System.out.println(i );} ????????????????????????????????? } ??? System.out.println( "素數個數是: " + count); } }
【程序3】??? 題目:打印出所有的 "水仙花數 ",所謂 "水仙花數 "是指一個三位數,其各位數字立方和等于該數本身。例如:153是一個 "水仙花數 ",因為153=1的三次方+5的三次方+3的三次方。 public class lianxi03 { public static void main(String[] args) { ???? int b1, b2, b3; ???? for(int m=101; m<1000; m++) { ????? b3 = m / 100; ????? b2 = m % 100 / 10; ????? b1 = m %??? 10; ????? if((b3*b3*b3 + b2*b2*b2 + b1*b1*b1) == m) { ????? System.out.println(m+"是一個水仙花數"); } ???? } } }???
【程序4】??? 題目:將一個正整數分解質因數。例如:輸入90,打印出90=2*3*3*5。??? 程序分析:對n進行分解質因數,應先找到一個最小的質數k,然后按下述步驟完成:??? (1)如果這個質數恰等于n,則說明分解質因數的過程已經結束,打印出即可。??? (2)如果n <> k,但n能被k整除,則應打印出k的值,并用n除以k的商,作為新的正整數你n,重復執行第一步。??? (3)如果n不能被k整除,則用k+1作為k的值,重復執行第一步。?? import java.util.*; public???? class???? lianxi04{ ??? public static void main(String[] args) { ??????? Scanner s = new Scanner(System.in); ??????? System.out.print( "請鍵入一個正整數:???? "); ??????? int??? n??? = s.nextInt(); ??????? int k=2; ??????? System.out.print(n + "=" ); ??????? while(k <= n) { ????????? if(k == n) {System.out.println(n);break;} ??????????? else if( n % k == 0) {System.out.print(k + "*");n = n / k; } ??????????????????? else??? k++; ?????????????????? } ???? } ??? } 【程序5】??? 題目:利用條件運算符的嵌套來完成此題:學習成績> =90分的同學用A表示,60-89分之間的用B表示,60分以下的用C表示。??? import java.util.*; public class lianxi05 { public static void main(String[] args) { ???? int x; ???? char grade; ???? Scanner s = new Scanner(System.in); ???? System.out.print( "請輸入一個成績: "); ???? x = s.nextInt();?? ???? grade = x >= 90 ? 'A' ?????????? : x >= 60 ? 'B' ?????????? :'C'; ??? System.out.println("等級為:"+grade); ?? } } 【程序6】??? 題目:輸入兩個正整數m和n,求其最大公約數和最小公倍數。??? /**在循環中,只要除數不等于0,用較大數除以較小的數,將小的一個數作為下一輪循環的大數,取得的余數作為下一輪循環的較小的數,如此循環直到較小的數的值為0,返回較大的數,此數即為最大公約數,最小公倍數為兩數之積除以最大公約數。* / import java.util.*; public??? class???? lianxi06???? { public static void main(String[] args) { int???? a ,b,m; Scanner s = new Scanner(System.in); System.out.print( "鍵入一個整數: "); a = s.nextInt(); System.out.print( "再鍵入一個整數: "); b = s.nextInt(); ????? deff cd = new deff(); ????? m = cd.deff(a,b); ????? int n = a * b / m; ????? System.out.println("最大公約數: " + m); ????? System.out.println("最小公倍數: " + n); } } class deff{ public int deff(int x, int y) { ???? int t; ???? if(x < y) { ????? t = x; ????? x = y; ????? y = t; ???? }?? ???? while(y != 0) { ????? if(x == y) return x; ????? else { ?????? int k = x % y; ?????? x = y; ?????? y = k; ????? } ???? } ???? return x; } } 【程序7】??? 題目:輸入一行字符,分別統計出其中英文字母、空格、數字和其它字符的個數。???
package?WuYang;
import?java.util.*;
public?class?lianxi07 {
public?static?void?main(String[] args) {
??int?abcCount=0;//英文字母個數
??int?spaceCount=0;//空格鍵個數
??int?numCount=0;//數字個數
??int?otherCount=0;//其他字符個數
??Scanner scan = new?Scanner(System.in);//掃描器接受控制臺的輸入信息
??System.out.println("輸入一組字符");
String str=scan.nextLine();//取出控制臺的一行信息,也就是你輸入的信息
?char[] ch = str.toCharArray();//把取道的字符串變成一個char數組
?????for(int?i=0;i<ch.length;i++){
??????if(Character.isLetter(ch[i])){
???????//判斷是否字母
???????abcCount++;
??????}
??????else?if(Character.isDigit(ch[i])){
???????//判斷是否數字
???????numCount++;
??????}
??????else?if(Character.isSpaceChar(ch[i])){
???????//判斷是否空格鍵
???????spaceCount++;
??????}
??????else{
???????//以上都不是則認為是其他字符
???????otherCount++;
??????}
?????}
?????System.out.println("字母個數:"+abcCount);
?????System.out.println("數字個數:"+numCount);
?????System.out.println("空格個數:"+spaceCount);
?????System.out.println("其他字符個數:"+otherCount);
?}
?
}
?
【程序8】??? 題目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一個數字。例如2+22+222+2222+22222(此時共有5個數相加),幾個數相加有鍵盤控制。??? import java.util.*; public class lianxi08 { public static void main(String[] args) { ???? long a , b = 0, sum = 0; ???? Scanner s = new Scanner(System.in); ???? System.out.print("輸入數字a的值: "); ???? a = s.nextInt(); ???? System.out.print("輸入相加的項數:"); ???? int n = s.nextInt(); ???? int i = 0; ???? while(i < n) { ????? b = b + a; ????? sum = sum + b; ????? a = a * 10; ????? ++ i; ???? } ????? System.out.println(sum); } } 【程序9】??? 題目:一個數如果恰好等于它的因子之和,這個數就稱為 "完數 "。例如6=1+2+3.編程???? 找出1000以內的所有完數。??? public class lianxi09 { public static void main(String[] args) { ???? System.out.println("1到1000的完數有: "); ???? for(int i=1; i<1000; i++) { ????? int t = 0; ????? for(int j=1; j<= i/2; j++) { ?????? if(i % j == 0) { ??????? t = t + j; ?????? } ????? } ????? if(t == i) { ?????? System.out.print(i + "???? "); ????? } ???? } }
}
【程序10】??? 題目:一球從100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在?第10次落地時,共經過多少米?第10次反彈多高? public?class?lianxi10 {
public?static?void?main(String[] args) {
??????double?h = 100,s = 0;
??????for(int?i=1; i<=10; i++) {
??????s = s + 2*h;
??????h = h / 2;
?????}
??????s=s-100;
?????System.out.println("經過路程:"?+ s);
?????System.out.println("最后高度:"?+ h);
?????
}
} ? 【程序11】??? 題目:有1、2、3、4四個數字,能組成多少個互不相同且一個數字中無重復數字的三位數?并把他們都輸入。??? public class lianxi11 { public static void main(String[] args) { ???? int count = 0; ???? for(int x=1; x<5; x++) { ????? for(int y=1; y<5; y++) { ?????? for(int z=1; z<5; z++) { ??????? if(x != y && y != z && x != z) { ???????? count ++; ???????? System.out.println(x*100 + y*10 + z ); ??????? } ?????? } ????? } ???? } ???? System.out.println("共有" + count + "個三位數"); } } 【程序12】??? 題目:企業發放的獎金根據利潤提成。利潤(I)低于或等于10萬元時,獎金可提10%;利潤高于10萬元,低于20萬元時,低于10萬元的部分按10%提成,高于10萬元的部分,可可提成7.5%;20萬到40萬之間時,高于20萬元的部分,可提成5%;40萬到60萬之間時高于40萬元的部分,可提成3%;60萬到100萬之間時,高于60萬元的部分,可提成1.5%,高于100萬元時,超過100萬元的部分按1%提成,從鍵盤輸入當月利潤,求應發放獎金總數???? import java.util.*; public class lianxi12 { public static void main(String[] args) { ???? double x = 0,y = 0; ???? System.out.print("輸入當月利潤(萬):"); ???? Scanner s = new Scanner(System.in); ???? x = s.nextInt(); ???? if(x > 0 && x <= 10) { ???? y = x * 0.1; ???? } else if(x > 10 && x <= 20) { ????? y = 10 * 0.1 + (x - 10) * 0.075; ???? } else if(x > 20 && x <= 40) { ????? y = 10 * 0.1 + 10 * 0.075 + (x - 20) * 0.05; ???? } else if(x > 40 && x <= 60) { ????? y = 10 * 0.1 + 10 * 0.075 + 20 * 0.05 + (x - 40) * 0.03; ???? } else if(x > 60 && x <= 100) { ????? y = 20 * 0.175 + 20 * 0.05 + 20 * 0.03 + (x - 60) * 0.015; ???? } else if(x > 100) { ????? y = 20 * 0.175 + 40 * 0.08 + 40 * 0.015 + (x - 100) * 0.01; ???? } ???? System.out.println("應該提取的獎金是 " + y + "萬"); } }
【程序13】??? 題目:一個整數,它加上100后是一個完全平方數,再加上168又是一個完全平方數,請問該數是多少???? public class lianxi13 { public static void main(String[] args) { ???? for(int x =1; x<100000; x++) { ????? if(Math.sqrt(x+100) % 1 == 0) { ?????? if(Math.sqrt(x+168) % 1 == 0) { ??????? System.out.println(x + "加100是一個完全平方數,再加168又是一個完全平方數"); ?????? } ????? } ???? } } } /*按題意循環應該從-100開始(整數包括正整數、負整數、零),這樣會多一個滿足條件的數-99。 但是我看到大部分人解這道題目時都把題中的“整數”理解成正整數,我也就隨大流了。*/
【程序14】?? 題目:輸入某年某月某日,判斷這一天是這一年的第幾天???? import java.util.*; public class lianxi14 { public static void main(String[] args) { ???? int year, month, day; ???? int days = 0; ???? int d = 0; ???? int e; ???? input fymd = new input(); ???? do { ???? e = 0; ???? System.out.print("輸入年:"); ???? year =fymd.input(); ???? System.out.print("輸入月:"); ???? month = fymd.input(); ???? System.out.print("輸入天:"); ???? day = fymd.input(); ???? if (year < 0 || month < 0 || month > 12 || day < 0 || day > 31) { ???? System.out.println("輸入錯誤,請重新輸入!"); ???? e=1 ; ???? } ???? }while( e==1);
????? for (int i=1; i <month; i++) { ????? switch (i) { ????? case 1: ????? case 3: ????? case 5: ????? case 7: ????? case 8: ????? case 10: ????? case 12: ?????? days = 31; ????? break; ????? case 4: ????? case 6: ????? case 9: ????? case 11: ?????? days = 30; ????? break; ????? case 2: ?????? if ((year % 400 == 0) || (year % 4 == 0 && year % 100 != 0)) { ??????? days = 29; ?????? } else { ??????? days = 28; ?????? } ?????? break; ????? } ????? d += days; ????? } ???? System.out.println(year + "-" + month + "-" + day + "是這年的第" + (d+day) + "天。"); } } class input{ public int input() { ???? int value = 0; ???? Scanner s = new Scanner(System.in); ???? value = s.nextInt(); ???? return value; } }
【程序15】??? 題目:輸入三個整數x,y,z,請把這三個數由小到大輸出。??? import java.util.*; public class lianxi15 { public static void main(String[] args) { ???? input fnc = new input(); ???? int x=0, y=0, z=0; ???? System.out.print("輸入第一個數字:"); ????? x = fnc.input(); ???? System.out.print("輸入第二個數字:"); ????? y = fnc.input(); ???? System.out.print("輸入第三個數字:"); ????? z = fnc.input();??? ??? if(x > y) { ????? int t = x; ????? x = y; ????? y = t; ???? } ??? if(x > z) { ????? int t = x; ????? x = z; ????? z = t; ???? } ??? if(y > z) { ????? int t = y; ????? y = z; ????? z = t; ???? } ??? System.out.println( "三個數字由小到大排列為: "+x + " " + y + " " + z); } } class input{ public int input() { ???? int value = 0; ???? Scanner s = new Scanner(System.in); ???? value = s.nextInt(); ???? return value; } } 【程序16】 題目:輸出9*9口訣。????? public class lianxi16 { public static void main(String[] args) { ???? for(int i=1; i<10; i++) { ????? for(int j=1; j<=i; j++) { ?????? System.out.print(j + "*" + i + "=" + j*i + "??? " ); ???????? if(j*i<10){System.out.print(" ");} } ????????? System.out.println(); ???? } } } 【程序17】??? 題目:猴子吃桃問題:猴子第一天摘下若干個桃子,當即吃了一半,還不癮,又多吃了一個???? 第二天早上又將剩下的桃子吃掉一半,又多吃了一個。以后每天早上都吃了前一天剩下???? 的一半零一個。到第10天早上想再吃時,見只剩下一個桃子了。求第一天共摘了多少。??? public class lianxi17 { public static void main(String[] args) { ???? int x = 1; ???? for(int i=2; i<=10; i++) { ????? x = (x+1)*2; ???? } ???? System.out.println("猴子第一天摘了 " + x + " 個桃子"); } }
【程序18】??? 題目:兩個乒乓球隊進行比賽,各出三人。甲隊為a,b,c三人,乙隊為x,y,z三人。已抽簽決定比賽名單。有人向隊員打聽比賽的名單。a說他不和x比,c說他不和x,z比,請編程序找出三隊賽手的名單。??? public class lianxi18 {
static char[] m = { 'a', 'b', 'c' }; static char[] n = { 'x', 'y', 'z' };
public static void main(String[] args) {
?? for (int i = 0; i < m.length; i++) { ??? for (int j = 0; j < n.length; j++) {
???? if (m[i] == 'a' && n[j] == 'x') {
????? continue;
} else if (m[i] == 'a' && n[j] == 'y') {
????? continue;
???? } else if ((m[i] == 'c' && n[j] == 'x')
?????? || (m[i] == 'c' && n[j] == 'z')) {
????? continue;
???? } else if ((m[i] == 'b' && n[j] == 'z')
?????? || (m[i] == 'b' && n[j] == 'y')) {
????? continue;
???? } else
????? System.out.println(m[i] + " vs " + n[j]);
??? }
?? }
}
}
【程序19】??? 題目:打印出如下圖案(菱形)??? ???? *??? ?? ***??? ?*****??? *******??? ?*****??? ?? ***??? ??? *??? public class lianxi19 { public static void main(String[] args) { ??? int H = 7, W = 7;//高和寬必須是相等的奇數 ??? for(int i=0; i<(H+1) / 2; i++) { ???? for(int j=0; j<W/2-i; j++) { ????? System.out.print(" ");
???? } ???? for(int k=1; k<(i+1)*2; k++) { ????? System.out.print('*'); ???? } ???? System.out.println(); ??? } ??? for(int i=1; i<=H/2; i++) { ???? for(int j=1; j<=i; j++) { ????? System.out.print(" "); ???? } ???? for(int k=1; k<=W-2*i; k++) { ????? System.out.print('*'); ???? } ???? System.out.println(); ??? } } }
【程序20】??? 題目:有一分數序列:2/1,3/2,5/3,8/5,13/8,21/13...求出這個數列的前20項之和。?
public class lianxi20 { public static void main(String[] args) { ??? int x = 2, y = 1, t; ??? double sum = 0; ??? for(int i=1; i<=20; i++) { ???? sum = sum + (double)x / y; ???? t = y; ???? y = x; ???? x = y + t; ???? } System.out.println("前20項相加之和是: " + sum); } }
【程序21】??? 題目:求1+2!+3!+...+20!的和??? public class lianxi21 { public static void main(String[] args) { ??? long sum = 0; ??? long fac = 1; ??? for(int i=1; i<=20; i++) { ???? fac = fac * i; ???? sum += fac; ??? } ??? System.out.println(sum); }
}
【程序22】??? 題目:利用遞歸方法求5!。??? public class lianxi22 { public static void main(String[] args) { ?????? int n = 5; ??? rec fr = new rec(); ??? System.out.println(n+"! = "+fr.rec(n)); } } class rec{ public long rec(int n) { ??? long value = 0 ; ??? if(n ==1 ) { ???? value = 1; ??? } else?? { ???? value = n * rec(n-1); ??? } ??? return value; } }
【程序23】??? 題目:有5個人坐在一起,問第五個人多少歲?他說比第4個人大2歲。問第4個人歲數,他說比第3個人大2歲。問第三個人,又說比第2人大兩歲。問第2個人,說比第一個人大兩歲。最后問第一個人,他說是10歲。請問第五個人多大????
public class lianxi23 { public static void main(String[] args) { ??? int age = 10; ???? for(int i=2; i<=5; i++) { ???? age =age+2; ??? } ??? System.out.println(age); } }
【程序24】??? 題目:給一個不多于5位的正整數,要求:一、求它是幾位數,二、逆序打印出各位數字。??? //使用了長整型最多輸入18位 import java.util.*; public class lianxi24 { public static void main(String[] args) { ?? Scanner s = new Scanner(System.in); ?? System.out.print("請輸入一個正整數:"); ?? long a = s.nextLong(); ?? String ss = Long.toString(a); ??? char[] ch = ss.toCharArray(); ??? int j=ch.length; ??? System.out.println(a + "是一個"+ j +"位數。"); ??? System.out.print("按逆序輸出是:"); ??? for(int i=j-1; i>=0; i--) { ??? System.out.print(ch[i]); ?? } ?? } ?? }
【程序25】??? 題目:一個5位數,判斷它是不是回文數。即12321是回文數,個位與萬位相同,十位與千位相同。??? import java.util.*; public class lianxi25 { public static void main(String[] args) { ??? Scanner s = new Scanner(System.in); ??? int a; ??? do{ ???? System.out.print("請輸入一個5位正整數:"); ????? a = s.nextInt(); ????? }while(a<10000||a>99999); ???? String ss =String.valueOf(a); ???? char[] ch = ss.toCharArray(); ???? if(ch[0]==ch[4]&&ch[1]==ch[3]){ ???? System.out.println("這是一個回文數");} ???? else {System.out.println("這不是一個回文數");} ??? } ??? } //這個更好,不限位數 import java.util.*; public class lianxi25a { public static void main(String[] args) { ?? Scanner s = new Scanner(System.in); ?? boolean is =true; ?? System.out.print("請輸入一個正整數:"); ?? long a = s.nextLong(); ?? String ss = Long.toString(a); ?? char[] ch = ss.toCharArray(); ?? int j=ch.length; ?? for(int i=0; i<j/2; i++) { ?? if(ch[i]!=ch[j-i-1]){is=false;} ?? } ?? if(is==true){System.out.println("這是一個回文數");} ???? else {System.out.println("這不是一個回文數");} ??? } ?? }
【程序26】??? 題目:請輸入星期幾的第一個字母來判斷一下是星期幾,如果第一個字母一樣,則繼續?? 判斷第二個字母。??? import java.util.*; public class lianxi26 { public static void main(String[] args) { ??? getChar tw = new getChar(); ??? System.out.println("請輸入星期的第一個大寫字母:"); ??? char ch = tw.getChar(); ??? switch(ch) { ???? case 'M': ????? System.out.println("Monday"); ????? break; ???? case 'W': ????? System.out.println("Wednesday"); ????? break; ???? case 'F': ????? System.out.println("Friday"); ????? break; ???? case 'T': { ????? System.out.println("請輸入星期的第二個字母:"); ????? char ch2 = tw.getChar(); ????? if(ch2 == 'U') {System.out.println("Tuesday"); } ????? else if(ch2 == 'H') {System.out.println("Thursday"); } ????? else {System.out.println("無此寫法!"); ?????? } ???? }; ????? break; ???? case 'S': { ?????? System.out.println("請輸入星期的第二個字母:"); ????? char ch2 = tw.getChar(); ????? if(ch2 == 'U') {System.out.println("Sunday"); } ?????? else if(ch2 == 'A') {System.out.println("Saturday"); } ?????? else {System.out.println("無此寫法!"); ?????? } ???? }; ????? break; default:System.out.println("無此寫法!"); } ?? } } class getChar{ public char getChar() { ??? Scanner s = new Scanner(System.in); ??? String str = s.nextLine(); ??? char ch = str.charAt(0); ??? if(ch<'A' || ch>'Z') { ???? System.out.println("輸入錯誤,請重新輸入"); ???? ch=getChar(); ??? } ??? return ch; } }??
【程序27】??? 題目:求100之內的素數??? //使用除sqrt(n)的方法求出的素數不包括2和3 public class lianxi27 { public static void main(String[] args) { ??? boolean b =false; ??? System.out.print(2 + " "); ??? System.out.print(3 + " "); ??? for(int i=3; i<100; i+=2) { ???? for(int j=2; j<=Math.sqrt(i); j++) { ????? if(i % j == 0) {b = false; ????????????????????? break; ?????? } else{b = true;} ???? } ?? if(b == true) {System.out.print(i + " ");} ??? } ?? } } //該程序使用除1位素數得2位方法,運行效率高通用性差。 public class lianxi27a { public static void main(String[] args) { ??? int[] a = new int[]{2, 3, 5, 7}; ?? for(int j=0; j<4; j++)System.out.print(a[j] + " "); ??? boolean b =false; ??? for(int i=11; i<100; i+=2) { ???? for(int j=0; j<4; j++) { ????? if(i % a[j] == 0) {b = false; ????????????????????? break; ?????? } else{b = true;} ???? } ?? if(b == true) {System.out.print(i + " ");} ??? } ?? } }
【程序28】??? 題目:對10個數進行排序??? import java.util.*; public class lianxi28 { public static void main(String[] args) { Scanner s = new Scanner(System.in); ?? int[] a = new int[10]; ?? System.out.println("請輸入10個整數:"); ?? for(int i=0; i<10; i++) { ??? a[i] = s.nextInt(); ?? }
?? for(int i=0; i<10; i++) { ??? for(int j=i+1; j<10; j++) { ???? if(a[i] > a[j]) { ????? int t = a[i]; ????? a[i] = a[j]; ????? a[j] = t; ???? } ??? } ?? } ?? for(int i=0; i<10; i++) { ??? System.out.print(a[i] + " "); ?? } } }
【程序29】??? 題目:求一個3*3矩陣對角線元素之和?
???? import java.util.*; public class lianxi29 { public static void main(String[] args) { ?? Scanner s = new Scanner(System.in); ?? int[][] a = new int[3][3]; System.out.println("請輸入9個整數:"); ?? for(int i=0; i<3; i++) { ??? for(int j=0; j<3; j++) { ???? a[i][j] = s.nextInt(); ??? } ?? } ?? System.out.println("輸入的3 * 3 矩陣是:"); ?? for(int i=0; i<3; i++) { ??? for(int j=0; j<3; j++) { ???? System.out.print(a[i][j] + " "); ??? } ??? System.out.println(); ?? } ?? int sum = 0; ?? for(int i=0; i<3; i++) { ??? for(int j=0; j<3; j++) { ???? if(i == j) { ????? sum += a[i][j]; ???? } ??? } ?? } ?? System.out.println("對角線之和是:" + sum); } }
【程序30】??? 題目:有一個已經排好序的數組。現輸入一個數,要求按原來的規律將它插入數組中。???? //此程序不好,沒有使用折半查找插入
import?java.util.*;
public?class?lianxi30?{
public?static?void?main(String[] args) {
???int[] a = new?int[]{1, 2, 6, 14, 25, 36, 37,55};
???int[] b = new?int[a.length+1];
??int?t1=0, t2 = 0; ??????????????????????????????????????????
???int?i =0;
???Scanner s= new?Scanner(System.in);
???System.out.print("請輸入一個整數:");
???int?num = s.nextInt();
???if(num >= a[a.length-1]) {
????b[b.length-1] = num;
????for(i=0; i<a.length; i++) {
?????b[i] = a[i];
????}
???} else?{
????for(i=0; i<a.length; i++) {
?????if(num >= a[i]) {
??????b[i] = a[i];
?????} else?{ ????
??????b[i] = num;
??????break;
?????}
????}
????for(int?j=i+1; j<b.length; j++) {
?????b[j] = a[j-1];
????}
???}
???for?(i = 0; i < b.length; i++) {
????System.out.print(b[i] + " ");
???}
} ??????????????????????????????????????
}
【程序31】 題目:將一個數組逆序輸出。?
?? import java.util.*; public class lianxi31 { public static void main(String[] args) { ?? Scanner s = new Scanner(System.in); ?? int a[] = new int[20]; System.out.println("請輸入多個正整數(輸入-1表示結束):"); ?? int i=0,j;?? do{ ?? ?? a[i]=s.nextInt(); ?? ?? i++; ?? }while (a[i-1]!=-1);
?? System.out.println("你輸入的數組為:"); ?? for( j=0; j<i-1; j++) { ??? System.out.print(a[j]+"?? "); } ?? System.out.println("\n數組逆序輸出為:"); ?? for( j=i-2; j>=0; j=j-1) { ??? System.out.print(a[j]+"?? "); } ??? } ?? } 【程序32】??? 題目:取一個整數a從右端開始的4~7位。??? import java.util.*; public class lianxi32 { public static void main(String[] args) { ??? Scanner s = new Scanner(System.in); ??? System.out.print("請輸入一個7位以上的正整數:"); ??? long a = s.nextLong(); ??? String ss = Long.toString(a); ??? char[] ch = ss.toCharArray(); ??? int j=ch.length; ??? if (j<7){System.out.println("輸入錯誤!");} ??? else { ???? System.out.println("截取從右端開始的4~7位是:"+ch[j-7]+ch[j-6]+ch[j-5]+ch[j-4]); ???? } ??? } ??? } 【程序33】?? 題目:打印出楊輝三角形(要求打印出10行如下圖)?????? ??????????? 1??? ????????? 1??? 1??? ??????? 1??? 2??? 1??? ????? 1??? 3??? 3??? 1??? ??? 1??? 4??? 6??? 4??? 1??? 1??? 5??? 10??? 10??? 5??? 1??? ………… public class lianxi33 { public static void main(String[] args) { ??? int[][] a = new int[10][10]; ?? for(int i=0; i<10; i++) { ??? a[i][i] = 1; ??? a[i][0] = 1; ?? } ?? for(int i=2; i<10; i++) { ??? for(int j=1; j<i; j++) { ???? a[i][j] = a[i-1][j-1] + a[i-1][j]; ??? } ?? } ???? for(int i=0; i<10; i++) { ??? for(int k=0; k<2*(10-i)-1; k++) { ???? System.out.print(" "); ??? } ??? for(int j=0; j<=i; j++) { ???? System.out.print(a[i][j] + "?? "); ??? } ??? System.out.println(); ?? } } } 【程序34】??? 題目:輸入3個數a,b,c,按大小順序輸出。??? import java.util.Scanner; public class lianxi34 { public static void main(String[] args) { ??? Scanner s = new Scanner(System.in); ??? System.out.println("請輸入3個整數:"); ??? int a = s.nextInt(); ??? int b = s.nextInt(); ??? int c = s.nextInt(); ????? if(a < b) { ???? int t = a; ???? a = b; ???? b = t; ??? } ????? if(a < c) { ???? int t = a; ???? a = c; ???? c = t; ??? } ???? if(b < c) { ???? int t = b; ???? b = c; ???? c = t; ??? } ??? System.out.println("從大到小的順序輸出:"); ??? System.out.println(a + " " + b + " " + c); } } 【程序35】??? 題目:輸入數組,最大的與第一個元素交換,最小的與最后一個元素交換,輸出數組。???
import?java.util.*;
public?class?lianxi35 {
public?static?void?main(String[] args) {
int?N = 8;
int[] a = new?int[N];// 創建一個八個元素的數組
Scanner s = new?Scanner(System.in);
int?idx1 = 0, idx2 = 0;
System.out.println("請輸入8個整數:");
for?(int?i = 0; i < N; i++) {
a[i] = s.nextInt();
}
// 獲得輸入的八個數字
System.out.println("你輸入的數組為:");
for?(int?i = 0; i < N; i++) {
System.out.print(a[i] + " ");
}
// 輸出輸入的數組
int?max = a[0], min = a[0];
for?(int?i = 0; i < N; i++) {
if?(a[i] > max) {
max = a[i];
idx1 = i;
}
// 找出最大的數和其下標
if?(a[i] < min) {
min = a[i];
idx2 = i;
}// 找出最大的數和其下標
}
?
if?(idx1 != 0) {
int?temp = a[0];
a[0] = a[idx1];
a[idx1] = temp;
}// 最大的數和第一個數交換位置
if?(idx2 != N - 1) {
int?temp = a[N - 1];
a[N - 1] = a[idx2];
a[idx2] = temp;
}// 最小的數和最后一個數交換位置
?
System.out.println("\n交換后的數組為:");
for?(int?i = 0; i < N; i++) {
System.out.print(a[i] + " ");
}
}
}
【程序36】??? 題目:有n個整數,使其前面各數順序向后移m個位置,最后m個數變成最前面的m個數??? import java.util.Scanner; public class lianxi36 { public static void main(String[] args) { ?? int N =10; ?? int[] a = new int[N]; ?? Scanner s = new Scanner(System.in); ?? System.out.println("請輸入10個整數:"); ?? for(int i=0; i<N; i++) { ??? a[i] = s.nextInt(); ?? } ?? System.out.print("你輸入的數組為:"); ?? for(int i=0; i<N; i++) { ???? System.out.print(a[i] + " "); ?? } ?? System.out.print("\n請輸入向后移動的位數:"); ?? int m = s.nextInt(); ?? int[] b = new int[m]; ?? for(int i=0; i<m; i++) { ??? b[i] = a[N-m+i]; ?? } ?? for(int i=N-1; i>=m; i--) { ?? a[i] = a[i-m]; ?? } ?? for(int i=0; i<m; i++) { ??? a[i] = b[i]; ?? } System.out.print("位移后的數組是:"); ?? for(int i=0; i<N; i++) { ??? System.out.print(a[i] + " "); ?? } } } 【程序37】??? 題目:有n個人圍成一圈,順序排號。從第一個人開始報數(從1到3報數),凡報到3的人退出圈子,問最后留下的是原來第幾號的那位。??? import java.util.Scanner; public class lianxi37 { public static void main(String[] args) { ?? Scanner s = new Scanner(System.in); ?? System.out.print("請輸入排成一圈的人數:"); ?? int n = s.nextInt(); ?? boolean[] arr = new boolean[n]; ?? for(int i=0; i<arr.length; i++) { ??? arr[i] = true; ?? }//數組賦值都是true ?? int leftCount = n; ?? int countNum = 0; ?? int index = 0; ?? while(leftCount > 1) { ??? if(arr[index] == true) { ???? countNum ++; ???? if(countNum == 3) { ????? countNum =0; ????? arr[index] = false; ????? leftCount --; ???? } ??? } ???? index ++; ???? if(index == n) { ???? index = 0; ??? } ?? } ??? for(int i=0; i<n; i++) { ??? if(arr[i] == true) { ???? System.out.println("原排在第"+(i+1)+"位的人留下了。"); ??? } ?? } } } 【程序38】??? 題目:寫一個函數,求一個字符串的長度,在main函數中輸入字符串,并輸出其長度。??? /*……………… *……題目意思似乎不能用length()函數???? */ import java.util.*; public class lianxi38 { public static void main(String[] args) { ??? Scanner s = new Scanner(System.in); ??? System.out.println("請輸入一個字符串:"); ??? String str = s.nextLine(); ???? System.out.println("字符串的長度是:"+str.length()); ??? } ??? } 【程序39】??? 題目:編寫一個函數,輸入n為偶數時,調用函數求1/2+1/4+...+1/n,當輸入n為奇數時,調用函數1/1+1/3+...+1/n(利用指針函數)??? //沒有利用指針函數 import java.util.*; public class lianxi39 { public static void main(String[] args) { ??? Scanner s = new Scanner(System.in); ??? System.out.print("請輸入一個正整數 n= "); ??? int n = s.nextInt(); ??? System.out.println("相應數列的和為:" + sum(n)); ?? } public static double sum(int n) { ??? double res = 0; ??? if(n % 2 == 0) { ???? for(int i=2; i<=n; i+=2) { ????? res += (double)1 / i; ???? } ??? } else { ???? for(int i=1; i<=n; i+=2) { ????? res += (double)1 / i ; ???? } ??? } ??? return res; } } 【程序40】??? 題目:字符串排序。??? public class lianxi40 { public static void main(String[] args) { ?? int N=5; ?? String temp = null; ?? String[] s = new String[N]; ?? s[0] = "matter"; ?? s[1] = "state"; ?? s[2] = "solid"; ?? s[3] = "liquid"; ?? s[4] = "gas"; ?? for(int i=0; i<N; i++) { ??? for(int j=i+1; j<N; j++) { ???? if(compare(s[i], s[j]) == false) { ????? temp = s[i]; ????? s[i] = s[j]; ????? s[j] = temp; ???? } ??? } ?? } ??? for(int i=0; i<N; i++) { ??? System.out.println(s[i]); ?? } } static boolean compare(String s1, String s2) { ?? boolean result = true; ?? for(int i=0; i<s1.length() && i<s2.length(); i++) { ??? if(s1.charAt(i) > s2.charAt(i)) { ???? result = false; ???? break; ??? } else if(s1.charAt(i) <s2.charAt(i)) { ???? result = true; ???? break; ??? } else { ???? if(s1.length() < s2.length()) { ????? result = true; ???? } else { ????? result = false; ???? } ??? } ?? } ?? return result; } } 【程序41】???題目:海灘上有一堆桃子,五只猴子來分。第一只猴子把這堆桃子憑據分為五份,多了一個,這只猴子把多的一個扔入海中,拿走了一份。第二只猴子把剩下的桃子又平均分成五份,又多了一個,它同樣把多的一個扔入海中,拿走了一份,第三、第四、第五只猴子都是這樣做的,問海灘上原來最少有多少個桃子???? public class lianxi41 { public static void main (String[] args) { int i,m,j=0,k,count; for(i=4;i<10000;i+=4) ?? { count=0; ???? m=i; ???? for(k=0;k<5;k++) ??????? { ???????? j=i/4*5+1; ???????? i=j; ???????? if(j%4==0) ??????????? count++; ??????????? else break; ?????? } ??? i=m; if(count==4) {System.out.println("原有桃子 "+j+" 個"); break;} } } } 【程序42】??? 題目:809*??=800*??+9*??+1??? 其中??代表的兩位數,8*??的結果為兩位數,9*??的結果為3位數。求??代表的兩位數,及809*??后的結果。??? //題目錯了!809x=800x+9x+1 這樣的方程無解。去掉那個1就有解了。 public class lianxi42 { public static void main (String[] args) { int a=809,b,i; for(i=10;i<13;i++) {b=i*a ; if(8*i<100&&9*i>=100) System.out.println ("809*"+i+"="+"800*"+i+"+"+"9*"+i+"="+b);} } } 【程序43】??? 題目:求0—7所能組成的奇數個數。??? //組成1位數是4個。 //組成2位數是7*4個。 //組成3位數是7*8*4個。 //組成4位數是7*8*8*4個。 //...... public class lianxi43 { public static void main (String[] args) { int sum=4; int j; System.out.println("組成1位數是 "+sum+" 個"); sum=sum*7; System.out.println("組成2位數是 "+sum+" 個"); for(j=3;j<=9;j++){ sum=sum*8; System.out.println("組成"+j+"位數是 "+sum+" 個"); } } } 【程序44】??? 題目:一個偶數總能表示為兩個素數之和。??? //由于用除sqrt(n)的方法求出的素數不包括2和3, //因此在判斷是否是素數程序中人為添加了一個3。 import java.util.*; public class lianxi44 { public static void main(String[] args) { Scanner s = new Scanner(System.in); int n,i; do{ ???? System.out.print("請輸入一個大于等于6的偶數:"); ???? n = s.nextInt(); ??? } while(n<6||n%2!=0);?? //判斷輸入是否是>=6偶數,不是,重新輸入 fun fc = new fun(); ??? for(i=2;i<=n/2;i++){ ??? if((fc.fun(i))==1&&(fc.fun(n-i)==1)) ??? {int j=n-i; ???? System.out.println(n+" = "+i+" + "+j); ???? } //輸出所有可能的素數對 ?? } } } class fun{ public int fun (int a)??? //判斷是否是素數的函數 { int i,flag=0; if(a==3){flag=1;return(flag);} for(i=2;i<=Math.sqrt(a);i++){ ?? if(a%i==0) {flag=0;break;} ????? else flag=1;} return (flag) ;//不是素數,返回0,是素數,返回1 } } //解法二 import java.util.*; public class lianxi44 { public static void main(String[] args) { Scanner s = new Scanner(System.in); int n; do{ ???? System.out.print("請輸入一個大于等于6的偶數:"); ???? n = s.nextInt(); ??? } while(n<6||n%2!=0);?? //判斷輸入是否是>=6偶數,不是,重新輸入
??? for(int i=3;i<=n/2;i+=2){ ??? if(fun(i)&&fun(n-i)) { ????? System.out.println(n+" = "+i+" + "+(n-i)); ????? } //輸出所有可能的素數對 ?? } } static boolean fun (int a){??? //判斷是否是素數的函數 boolean flag=false; if(a==3){flag=true;return(flag);} for(int i=2;i<=Math.sqrt(a);i++){ ?? if(a%i==0) {flag=false;break;} ????? else flag=true;} return (flag) ; } } 【程序45】??? 題目:判斷一個素數能被幾個9整除??? //題目錯了吧?能被9整除的就不是素數了!所以改成整數了。 import java.util.*; public class lianxi45 { public static void main (String[] args) { ?? Scanner s = new Scanner(System.in); ?? System.out.print("請輸入一個整數:"); ??? int num = s.nextInt(); ??? int?? tmp = num; ??? int count = 0; ?????? for(int i = 0 ; tmp%9 == 0 ;){ ?????????? tmp = tmp/9; ??????????? count ++; ????????? } ???? System.out.println(num+" 能夠被 "+count+" 個9整除。"); ???? } } 【程序46】??? 題目:兩個字符串連接程序??? import java.util.*; public class lianxi46 { public static void main(String[] args) { ??? Scanner s = new Scanner(System.in); ??? System.out.print("請輸入一個字符串:"); ??? String str1 = s.nextLine(); ??? System.out.print("請再輸入一個字符串:"); ??? String str2 = s.nextLine(); ??? String str = str1+str2; ??? System.out.println("連接后的字符串是:"+str); ??? } ??? } 【程序47】??? 題目:讀取7個數(1—50)的整數值,每讀取一個值,程序打印出該值個數的*。??? import java.util.*; public class lianxi47 { public static void main(String[] args) { Scanner s = new Scanner(System.in); int n=1,num; while(n<=7){ ???????? do{ ????????? System.out.print("請輸入一個1--50之間的整數:"); ???????????? num= s.nextInt(); ?????????? }while(num<1||num>50); ????? for(int i=1;i<=num;i++) ????? {System.out.print("*"); ????? } System.out.println(); n ++; } } } 【程序48】??? 題目:某個公司采用公用電話傳遞數據,數據是四位的整數,在傳遞過程中是加密的,加密規則如下:每位數字都加上5,然后用和除以10的余數代替該數字,再將第一位和第四位交換,第二位和第三位交換。??? import java.util.*; public class lianxi48?? { public static void main(String args[]) { Scanner s = new Scanner(System.in); int num=0,temp; do{ ?? System.out.print("請輸入一個4位正整數:"); ????? num = s.nextInt(); ???? }while (num<1000||num>9999); int a[]=new int[4]; a[0] = num/1000; //取千位的數字 a[1] = (num/100)%10; //取百位的數字 a[2] = (num/10)%10; //取十位的數字 a[3] = num%10; //取個位的數字 for(int j=0;j<4;j++) { a[j]+=5; a[j]%=10; } for(int j=0;j<=1;j++) ??? { ??? temp = a[j]; ??? a[j] = a[3-j]; ??? a[3-j] =temp; ??? } System.out.print("加密后的數字為:"); for(int j=0;j<4;j++) System.out.print(a[j]); } } 【程序49】??? 題目:計算字符串中子串出現的次數??? import java.util.*; public class lianxi49 { public static void main(String args[]){ Scanner s = new Scanner(System.in); ??? System.out.print("請輸入字符串:"); ??? String str1 = s.nextLine(); ??? System.out.print("請輸入子串:"); ??? String str2 = s.nextLine(); int count=0; if(str1.equals("")||str2.equals("")) ?? { ?? System.out.println("你沒有輸入字符串或子串,無法比較!"); ?? System.exit(0); ?? } else ?? { ??? for(int i=0;i<=str1.length()-str2.length();i++) ???? { ???? if(str2.equals(str1.substring(i, str2.length()+i))) ????? //這種比法有問題,會把"aaa"看成有2個"aa"子串。 ?????? count++; ?????? } System.out.println("子串在字符串中出現: "+count+" 次"); } } } 【程序50】??? 題目:有五個學生,每個學生有3門課的成績,從鍵盤輸入以上數據(包括學生號,姓名,三門課成績),計算出平均成績,把原有的數據和計算出的平均分數存放在磁盤文件 "stud "中。 import java.io.*; import java.util.*; public class lianxi50 { public static void main(String[] args){ ?? Scanner ss = new Scanner(System.in); ?? String [][] a = new String[5][6]; ?? for(int i=1; i<6; i++) { ??? System.out.print("請輸入第"+i+"個學生的學號:"); ??? a[i-1][0] = ss.nextLine(); ??? System.out.print("請輸入第"+i+"個學生的姓名:"); ??? a[i-1][1] = ss.nextLine(); ??? for(int j=1; j<4; j++) { ?????? System.out.print("請輸入該學生的第"+j+"個成績:"); ?????? a[i-1][j+1] = ss.nextLine(); ?????? } System.out.println("\n"); ?? } //以下計算平均分 float avg; int sum; for(int i=0; i<5; i++) { sum=0; ?? for(int j=2; j<5; j++) { ?? sum=sum+ Integer.parseInt(a[i][j]); ????? } ?? avg= (float)sum/3; ?? a[i][5]=String.valueOf(avg); } //以下寫磁盤文件 String s1; try { ??? File f = new File("C:\\stud"); ??? if(f.exists()){ ????? System.out.println("文件存在"); ????? }else{ ???????? System.out.println("文件不存在,正在創建文件"); ????????? f.createNewFile();//不存在則創建 ??????? } BufferedWriter output = new BufferedWriter(new FileWriter(f)); for(int i=0; i<5; i++) { for(int j=0; j<6; j++) { ?? s1=a[i][j]+"\r\n"; ?? output.write(s1);??? ??? } } output.close(); System.out.println("數據已寫入c盤文件stud中!"); ?? } catch (Exception e) { ???? e.printStackTrace(); ???? } } }
自己寫的程序:
1、?判斷一個數是否為素數
public?class?lianxi33 {
public?static?void?main(String[] args) {
for?(int?i = 1; i <=10000; i++) {
int?n = i;
if?(isPrime(n)) {
System.out.println(i + "是素數");
}
?
}
?
}
?
// 輸入一個數判斷其是否為素數
public?static?boolean?isPrime(int?n) {
if?(n <= 1) {
return?false;
}
if?(n == 2) {
return?true;
}
if?(n % 2 == 0) {
return?false;
}
for?(int?i = 3; i <= (int) (Math.floor(Math.sqrt(n))) + 1; i = i + 2) {
if?(n % i == 0) {
return?false;
}
}
return?true;
}
?
}
?
2、二分法查找
public?class?BinarySearch {
?
public?static?int?binarySearch(int[] a, int?x) {
// 在a[0]<=a[1]<=...<=a[n-1]中搜索x
// 找到x則返回x的所在位置,否則返回-1
int?left = 0;
int?right = a.length?- 1;
?
while?(left <= right) {
int?middle = (left + right) / 2;
if?(x == a[middle])
return?middle;
if?(x > a[middle])
left = middle + 1;
else
right = middle - 1;
}
return?-1;
}
?
public?static?void?main(String[] args) {
int[] a = { 0, 1, 3, 6, 7, 10, 21, 34, 36, 40, 76 };
int?x = 34;// 設定要查找的數
int?position = binarySearch(a, x);
System.out.println(x + "在數組中的位置是"?+ position);
?
}
}
?
2、?比較器 二分查找
???import?java.util.TreeSet;
import?java.util.Iterator;
?
public?class?Student implements?Comparable<Student> {
????????private?int?id;
????????private?String name;
????????private?String dengji;
?
????????public?Student (int?id, String name, String dengji) {
????????????????this.id?= id;
????????????????this.name?= name;
????????????????this.dengji=dengji;
????????}
?
????????public?void?setId (int?id) {
????????????????this.id?= id;
????????}
?
????????public?void?setName (String name) {
????????????????this.name?= name;
????????}
????????public?void?setDengji (String dengji) {
????????????this.dengji?= dengji;
????}
?
????????public?int?getId () {
????????????????return?id;
????????}
?
????????public?String getName () {
????????????????return?name;
????????}
????????public?String getdengji () {
????????????return?dengji;
????}
?
????????/* Student 類的字符串表達式,形如:
?????????* 2 ??張三 */
?
????????public?String toString () {
????????????????return?(id?+ "\t"?+ name+"\t"?+ dengji);
????????}
?
????????/* 實現 Comparable 接口中的 compareTo 方法,
?????????* 通常大于時返回一個正數,小于時返回一個負數,
?????????* 等于時返回零,具體情況可以自行決定。
?????????*********************************************************
?????????* 這里我根據 id 號的大小進行了比較。由于 TreeSet
?????????* 會根據 compareTo 的結果來排序,因此輸出結果
?????????* 應該是按照 id 號從小到大排序的。
?????????* 如果要根據姓名進行排序,只需對這個方法進行相應的修改。*/
?
????????public?int?compareTo (Student arg) {
????????????????if?(id?> arg.id)
????????????????????????return?1;
????????????????else?if?(id?== arg.id)
????????????????????????return?0;
????????????????else
????????????????????????return?-1;
????????}
?
????????/* 以下為主方法,輸出結果是:
?????????* 3 ????John
?????????* 5 ????Tom
?????????* 7 ????Alice
?????????* 9 ????David
?????????* 可以看到不同于輸入順序,
?????????* TreeSet 已經將其排序了。*/
?
????????public?static?void?main (String args[]) {
????????????????TreeSet<Student> tset = new?TreeSet<Student>();
????????????????tset.add(new?Student(5, "Tom"?, ?"a"));
????????????????tset.add(new?Student(3, "John", ?"b"?));
????????????????tset.add(new?Student(9, "David", ?"c"?));
????????????????tset.add(new?Student(7, "Alice"?, "d"));
?
????????????????Iterator<Student> itor = tset.iterator();
????????????????while?(itor.hasNext()) {
????????????????????????System.out.println(itor.next().toString());
????????????????}
????????}
}
?
**************************************************************************************************************************************************************
BinarySearch
import?java.util.Comparator;
?
public?class?BinarySearch?{
public?static?<T extends?Comparable<T>> int?binarySearch(T[] a, T x,
Comparator<T> comparator) {
if?(a == null) {
throw?new?IllegalArgumentException("被查找數組為null!");
} else?if?(x == null) {
throw?new?IllegalArgumentException("被查詢元素為null!");
}
?
int?left = 0;
int?right = a.length?- 1;
?
while?(left <= right) {
int?middle = (left + right) / 2;
if?(comparator != null) {
if?(comparator.compare(x, a[middle]) == 0)
return?middle;
if?(comparator.compare(x, a[middle]) > 0)
left = middle + 1;
else
right = middle - 1;
}
?
??else?{ if(x.compareTo(a[middle])==0)
??return?middle;
??if(x.compareTo(a[middle])>0)
??left = middle + 1;
??else?right = middle - 1; }
?
}
return?-1;
}
?
public?static?void?main(String[] args) {
Student[] a = new?Student[4];
a[0] = (new?Student(3, "Tom"));
a[1] = (new?Student(5, "John"));
a[2] = (new?Student(7, "David"));
a[3] = (new?Student(9, "Alice"));
?
Student x = new?Student(7, "John");// 設定要查找的數
?
int?position = binarySearch(a, x, new?StudentComparator());
System.out.println(x + "在數組中的位置是"?+ position);
?
}
}
?
Student
import java.util.TreeSet;
import java.util.Iterator;
?
public class Student implements Comparable<Student> {
???????private int id;
???????private String name;
???????
?
???????public Student (int id, String name) {
???????????????this.id = id;
???????????????this.name = name;
???????????????
???????}
?
???????public void setId (int id) {
???????????????this.id = id;
???????}
?
???????public void setName (String name) {
???????????????this.name = name;
???????}
???????
?
???????public int getId () {
???????????????return id;
???????}
?
???????public String getName () {
???????????????return name;
???????}
???????
?
???????/* Student 類的字符串表達式,形如:
????????* 2 ??張三 */
?
???????public String toString () {
???????????????return (id + "\t" + name+"\t" );
???????}
?
???????/* 實現 Comparable 接口中的 compareTo 方法,
????????* 通常大于時返回一個正數,小于時返回一個負數,
????????* 等于時返回零,具體情況可以自行決定。
????????*********************************************************
????????* 這里我根據 id 號的大小進行了比較。由于 TreeSet
????????* 會根據 compareTo 的結果來排序,因此輸出結果
????????* 應該是按照 id 號從小到大排序的。
????????* 如果要根據姓名進行排序,只需對這個方法進行相應的修改。*/
?
???????public int compareTo (Student arg) {
???????????????if (id > arg.id)
???????????????????????return 1;
???????????????else if (id == arg.id)
???????????????????????return 0;
???????????????else
???????????????????????return -1;
???????}
?
???????/* 以下為主方法,輸出結果是:
????????* 3 ????John
????????* 5 ????Tom
????????* 7 ????Alice
????????* 9 ????David
????????* 可以看到不同于輸入順序,
????????* TreeSet 已經將其排序了。*/
?
???????public static void main (String args[]) {
???????????TreeSet<Student> tset = new TreeSet<Student>();
???????????tset.add(new Student(5, "Tom" ));
???????????tset.add(new Student(3, "John"));
???????????tset.add(new Student(9, "David"));
???????????tset.add(new Student(7, "Alice"));
?
???????????Iterator<Student> itor = tset.iterator();
???????????while (itor.hasNext()) {
???????????????????System.out.println(itor.next().toString());
???????????}
???}
}
StudentComparator
import?java.util.Comparator;
?
/**
?* Student 比較器
?*/
public?class?StudentComparator?implements?Comparator<Student>
{
@Override
public?int?compare(Student s1, Student s2)
{
if(s1.getId()>s2.getId())
return?1;
else?if(s1.getId()==s2.getId())
return?0;
else
return?-1;
}
}
package test1;? ? /** ?* Title: Hello Java World ?* Description: 簡單的Java程序,只顯示一個信息。 ?* filename: HelloWorld.java ?*/? ?public class HelloWorld {? ? public static void main(String[] args) {? ??? System.out.println("Hello Java World!");? ? }? ?}?
package test2;? /** ?* Title: Java語言流程演示 ?* Description: 演示Java中幾種常用的流程控制操作 ?* Filename: flowDome.java ?*/? ?public class flowDemo{? ?? public static void main(String[] arges){? ???? int iPara1,iPara2,iEnd;? ???? if(arges.length!=3)? ???? {? ?????? System.out.println("USE :java flowDome parameter1 parameter2 circle");? ?????? System.out.println("parameter1 : 比較條件1,數字類型");? ?????? System.out.println("parameter2 : 比較條件2,數字類型");? ?????? System.out.println("circle :循環次數");? ?????? System.out.println("ego:java flowDome 1 2 5");? ?????? return;? ???? }else{? ?????? iPara1 = Integer.parseInt(arges[0]);? ?????? iPara2 = Integer.parseInt(arges[1]);? ?????? iEnd = Integer.parseInt(arges[2]);? ???? }? ???? //if語句? ???? if(iPara2>iPara1)? ???? {? ????? System.out.println("if 條件滿足!");? ????? System.out.println("第2個數比第1個數大!");? ???? }? ???? else? ???? {? ????? System.out.println("if 條件不滿足!");? ????? System.out.println("第2個數比第1個數小!");? ???? }? ???? //for循環操作? ???? for(int i=0;i<iEnd;i++)? ???? {? ?????? System.out.println("這是for 第"+i+"次循環");? ???? }? ???? //while循環操作? ???? int i=0;? ???? while(i<iEnd)? ???? {? ????? System.out.println("這是while 第"+i+"次循環");? ????? i++;? ???? }? ???? //do-while循環操作? ???? int j=0;? ???? do? ???? {? ????? System.out.println("這是do-while 第"+j+"次循環");? ????? j++;? ???? }while(j<iEnd);? ?? }? ?}?
package test3;? ? /** ?* Title: 數組數據操作 ?* Description: 演示一維數組和多維數組的初始化和基本操作 ?* Filename: myArray.java ?*/? ?public class? myArray{? ?? //初始化數組變量? ?? char[] cNum = {'1','2','3','4','5','6','7','8','9','0'};? ?? char[] cStr = {'a','b','c','d','e','f','g','h',? ????????????????? 'i','j','k','l','m','n','o','p',? ????????????????? 'q','r','s','t','u','v','w','x','y','z'};? ?? int[] iMonth = {31,28,31,30,31,30,31,31,30,31,30,31};? ?? String[] sMail = {"@","."};? /** ?*<br>方法說明:校驗電子郵件 ?*<br>輸入參數:String sPara 被校驗的電子郵件字符 ?*<br>返回類型:boolean 如果校驗的格式符合電子郵件格式返回true;否則返回false ?*/???? ?? public boolean isMail(String sPara){? ??? for(int i=0;i<sMail.length;i++){? ????? if(sPara.indexOf(sMail[i])==-1)? ??????? return false;?????????? ??? }? ??? return true;? ?? }? /** ?*<br>方法說明:判斷是否是數字 ?*<br>輸入參數:String sPara。 需要判斷的字符串 ?*<br>返回類型:boolean。如果都是數字類型,返回true;否則返回false ?*/???? ?? public boolean isNumber(String sPara){? ???? int iPLength = sPara.length();? ???? for(int i=0;i<iPLength;i++){? ????? char cTemp = sPara.charAt(i);? ????? boolean bTemp = false;? ????? for(int j=0;j<cNum.length;j++){? ??????? if(cTemp==cNum[j]){? ????????? bTemp = true;? ????????? break;? ??????? }? ????? }? ????? if(!bTemp) return false;?? ???? }? ??? return true;? ?? }? /** ?*<br>方法說明:判斷是否都是英文字符 ?*<br>輸入參數:String sPara。要檢查的字符 ?*<br>返回類型:boolean。如果都是字符返回true;反之為false ?*/???? ?? public boolean isString(String sPara){? ???? int iPLength = sPara.length();? ???? for(int i=0;i<iPLength;i++){? ????? char cTemp = sPara.charAt(i);? ????? boolean bTemp = false;? ????? for(int j=0;j<cStr.length;j++){? ??????? if(cTemp==cStr[j]){? ????????? bTemp = true;? ????????? break;? ??????? }? ????? }? ????? if(!bTemp) return false;?? ???? }? ??? return true;? ?? }? /** ?*<br>方法說明:判斷是否是閏年 ?*<br>輸入參數:int iPara。要判斷的年份 ?*<br>返回類型:boolean。如果是閏年返回true,否則返回false ?*/???? ?? public boolean chickDay(int iPara){? ???? return iPara%100==0&&iPara%4==0;? ?? }? /** ?*<br>方法說明:檢查日期格式是否正確 ?*<br>輸入參數:String sPara。要檢查的日期字符 ?*<br>返回類型:int 0 日期格式正確,-1 月或這日不合要求, -2 年月日格式不正確? ?*/? ?? public int chickData(String sPara){
??? @SuppressWarnings("unused")? ??? boolean bTemp = false;? ??? //所輸入日期長度不正確? ??? if(sPara.length()!=10) return -2;?
//獲取年? ??? String sYear = sPara.substring(0,4);?
//判斷年是否為數字? ??? if(!isNumber(sYear)) return -2;
//獲取月份? ??? String sMonth = sPara.substring(5,7);?2011 05 05 ??? //判斷月份是否為數字? ??? if(!isNumber(sMonth)) return -2;? ??? //獲取日? ??? String sDay = sPara.substring(8,10);? ??? //判斷日是否為數字? ??? if(!isNumber(sDay)) return -2;? ??? //將年、月、日轉換為數字?
??? int iYear = Integer.parseInt(sYear);? ??? int iMon = Integer.parseInt(sMonth);? ??? int iDay = Integer.parseInt(sDay);? ??? if(iMon>12) return -1;? ??? //閏年二月處理? ??? if(iMon==2&&chickDay(iYear)){? ????? if(iDay>29) return 2;? ??? }else{? ????? if(iDay>iMonth[iMon-1]) return -1;? ??? }? ??? return 0;? ?? }? /** ?*<br>方法說明:主方法,測試用 ?*<br>輸入參數: ?*<br>返回類型: ?*/?? ?? public static void main(String[] arges){? ???? myArray mA = new myArray();? ???? //校驗郵件地址? ???? boolean bMail = mA.isMail("tom@163.com");? ???? System.out.println("1 bMail is "+bMail);? ???? bMail = mA.isMail("tom@163com");? ???? System.out.println("2 bMail is "+bMail);? ???? //演示是否是數字? ???? boolean bIsNum = mA.isNumber("1234");? ???? System.out.println("1:bIsNum="+bIsNum);? ???? bIsNum = mA.isNumber("123r4");? ???? System.out.println("2:bIsNum="+bIsNum);? ???? //演示是否是英文字符? ???? boolean bIsStr = mA.isString("wer");? ???? System.out.println("1:bIsStr="+bIsStr);? ???? bIsStr = mA.isString("wer3");? ???? System.out.println("2:bIsStr="+bIsStr);? ???? //演示檢查日期? ???? int iIsTime = mA.chickData("2003-12-98");? ???? System.out.println("1:iIsTime="+iIsTime);? ???? iIsTime = mA.chickData("2003-111-08");? ???? System.out.println("2:iIsTime="+iIsTime);? ???? iIsTime = mA.chickData("2003-10-08");? ???? System.out.println("3:iIsTime="+iIsTime);? ???? iIsTime = mA.chickData("2000-02-30");? ???? System.out.println("4:iIsTime="+iIsTime);? ?? }? ?}?
package test4;? ? import java.util.*;? /** ?* Title: 矢量操作< ?* Description: 演示一個矢量(Vector)的基本操作 ?* Filename: operateVector.java ?*/? public class operateVector?? {? /* *<br>方法說明:生成一個4*4的二維Vector,供使用。 *<br>輸入參數: *<br>輸出變量:Vector *<br>其它說明: */? ??? public Vector<Object> buildVector(){? ?????? Vector<Object> vTemps = new Vector<Object>();? ?????? for(int i=0;i<4;i++){? ????????? Vector<Object> vTemp = new Vector<Object>();? ????????? for (int j=0;j<4;j++){? ??????????? vTemp.addElement("Vector("+i+")("+j+")");? ????????? }? ????????? vTemps.addElement(vTemp);? ?????? }? ?????? return vTemps;? ??? }? /* *<br>方法說明:插入數據 *<br>輸入參數:Vector vTemp 待插入的數據對象 *<br>輸入參數:int iTemp 插入數據的位置 *<br>輸入參數:Object oTemp 插入數據值 *<br>輸出變量:Vector 結果 *<br>其它說明:如果插入位置超出實例實際的位置將返回null
*/? ??? public Vector<Object> insert(Vector<Object> vTemp,int iTemp,Object oTemp){? ??????? if(iTemp>vTemp.size()){? ??????????? print("數據超界!");? ??????????? return null;? ??????? }else{? ???????????? vTemp.insertElementAt(oTemp,iTemp);? ??????? }? ??????? return vTemp;? ??? }? /* *<br>方法說明:移除數據 *<br>輸入參數:Vector vTemp 待刪除矢量對象 *<br>輸入參數:int iTemp 刪除數據的位置 *<br>輸出變量:Vector *<br>其它說明:如果刪除超界的數據,將返回null */? ??? public Vector<Object> delete(Vector<Object> vTemp,int iTemp){? ??????? if(iTemp>vTemp.size()){? ??????????? print("數據超界!");? ??????????? return null;? ??????? }else{? ???????????? vTemp.removeElementAt(iTemp);? ??????? }? ??????? return vTemp;? ??? }? /* *<br>方法說明:修改數據 *<br>輸入參數:Vector vTemp 待修改矢量對象 *<br>輸入參數:int iTemp 修改數據的位置 *<br>輸入參數:Object oTemp 修改數據值 *<br>輸出變量:Vector *<br>其它說明:如果修改位置超界的數據,將返回null */? ??? public Vector<Object> updata(Vector<Object> vTemp,int iTemp,Object oTemp){? ??????? if(iTemp>vTemp.size()){? ??????????? print("數據超界!");? ??????????? return null;? ??????? }else{? ???????????? vTemp.setElementAt(oTemp,iTemp);? ??????? }? ??????? return vTemp;? ??? }? /* *<br>方法說明:輸出信息 *<br>輸入參數:String sTemp 輸出信息名稱 *<br>輸入參數:Object oTemp 輸出信息值 *<br>返回變量:無 */? ??? public void print(String sTemp,Vector<Object> oTemp){? ??????? System.out.println(sTemp+"數據:");? ??????? this.print(oTemp);? ??? }? /** ?*<br>方法說明:打印輸出(過載) ?*<br>輸入參數:Object oPara 輸出的對象 ?*<br>返回類型:無 ?*/? ??? public void print(Object oPara){? ??????? System.out.println(oPara);? ??? }? /** ?*<br>方法說明:打印輸出(過載) ?*<br>輸入參數:Vector vPara 顯示輸出矢量對象 ?*<br>返回類型:無 ?*/? ??? public void print(Vector<Object> vPara){? ?????? for(int i=0;i<vPara.size();i++){? ??????? System.out.println(vPara.elementAt(i));? ?????? }? ??? }? /** ?*<br>方法說明:主方法,程序入口 ?*<br>輸入參數:String[] args ?*<br>返回類型:無 ?*/? ??? public static void main(String[] args)?? ??? {? ??????? operateVector ov = new operateVector();? ??????? Vector<Object> vTemp = ov.buildVector();? ??????? ov.print("vTemp0",vTemp);? ??????? Vector<Object> vResult = ov.insert(vTemp,2,"添加的數據");? ??????? ov.print("vResult",vResult);? ??????? Vector<Object> vResultup = ov.updata(vResult,2,"修改的數據");? ??????? ov.print("vResultmp",vResultup);? ??????? Vector<Object> vResultnow = ov.delete(vResultup,2);? ??????? ov.print("vResultnow",vResultnow);? ??? }? }?
package test5;? ? import java.util.*;? /** ?* Title: 哈希表操作 ?* Description: 這是一個權限認證的例子,使用了哈希表作為數據的存儲 ?* Filename: RoleRight.java ?*/? ?public class RoleRight? ?{? ?private static Hashtable<String, String> rightList = new Hashtable<String, String>();? /** ?*<br>方法說明:初始化數據 ?*<br>輸入參數: ?*<br>返回類型: ?*/? ?public void init()? ?{? ??? String[] accRoleList = {"admin","satrap","manager","user","guest"};? ??? String[] rightCodeList = {"10001","10011","10021","20011","24011"};? ??? for(int i=0;i<accRoleList.length;i++)? ??? {? ????? rightList.put(accRoleList[i],rightCodeList[i]);? ??? }? ?}? /** ?*<br>方法說明:獲取角色權限代碼 ?*<br>輸入參數:String accRole 角色名稱 ?*<br>返回類型:String 權限代碼 ?*/? ?public String getRight(String accRole)? ?{? ??? if(rightList.containsKey(accRole))? ????? return (String)rightList.get(accRole);? ??? else? ????? return null;? ?}? /** ?*<br>方法說明:添加角色和代碼信息 ?*<br>輸入參數:String accRole 角色名稱 ?*<br>輸入參數:String rightCode 角色權限代碼? ?*<br>返回類型:void (無) ?*/? ?public void insert(String accRole,String rightCode)? ?{? ?? rightList.put(accRole,rightCode);? ?}? /** ?*<br>方法說明:刪除角色權限 ?*<br>輸入參數:String accRole 角色名稱 ?*<br>返回類型:void(無) ?*/? ?public void delete(String accRole)? ?{? ?? if(rightList.containsKey(accRole))? ???? rightList.remove(accRole);? ?}? /** ?*<br>方法說明:修改角色權限代碼 ?*<br>輸入參數:String accRole 角色名稱 ?*<br>輸入參數:String rightCode 角色權限代碼? ?*<br>返回類型:void(無) ?*/? ?public void update(String accRole,String rightCode)? ?{? ?? //this.delete(accRole);? ?? this.insert(accRole,rightCode);? ?}? /** ?*<br>方法說明:打印哈希表中角色和代碼對應表 ?*<br>輸入參數:無 ?*<br>返回類型:無 ?*/? ?public void print()? ?{? ??? Enumeration<String> RLKey = rightList.keys();? ??? while(RLKey.hasMoreElements())? ??? {? ??????? String accRole = RLKey.nextElement().toString();? ??????? print(accRole+"="+this.getRight(accRole));? ??? }? ?}? /** ?*<br>方法說明:打印信息(過載) ?*<br>輸入參數:Object oPara 打印的信息內容 ?*<br>返回類型:無 ?*/? ?public void print(Object oPara)? ?{? ??? System.out.println(oPara);? ?}? /** ?*<br>方法說明:主方法, ?*<br>輸入參數: ?*<br>返回類型: ?*/? ?public static void main(String[] args)? ?{? ??? RoleRight RR = new RoleRight();? ??? RR.init();? ??? RR.print();? ??? RR.print("___________________________");? ??? RR.insert("presider","10110");? ??? RR.print();? ??? RR.print("___________________________");? ??? RR.update("presider","10100");? ??? RR.print();? ??? RR.print("___________________________");? ??? RR.delete("presider");? ??? RR.print();? ?}?? ?}//end:)~?
package test6;? ? /** ?* Title: 樹參數 ?* Description: 使用繼承類,柳樹就是樹 ?* Filename: osier.java ?*/? class tree? {? /** ?*<br>方法說明:樹的樹根 ?*/? ? public void root()? ? {? ??? String sSite = "土壤中";? ??? String sFunction = "吸收養份";? ??? print("位置:"+sSite);? ??? print("功能:"+sFunction);? ? }? /** ?*方法說明:樹的樹干 ?*/? ? public void bolo()? ? {? ??? String sSite = "地面";? ??? String sFunction = "傳遞養份";? ??? print("位置:"+sSite);? ??? print("功能:"+sFunction);? ? }? /** ?*方法說明:樹的樹枝 ?*/? ? public void branch()? ? {? ??? String sSite = "樹干上";? ??? String sFunction = "傳遞養份";? ??? print("位置:"+sSite);? ??? print("功能:"+sFunction);? ? }? /** ?*方法說明:樹的葉子 ?*/? ? public void leaf()? ? {? ??? String sSite = "樹梢";? ??? String sFunction = "光合作用";? ??? String sColor = "綠色";
??? print("位置:"+sSite);? ??? print("功能:"+sFunction);? ??? print("顏色:"+sColor);? ? }? /** ?*方法說明:顯示信息 ?*輸入參數:Object oPara 顯示的信息 ?*/? ? public void print(Object oPara)? ? {? ??? System.out.println(oPara);? ? }? /** ?*方法說明:主方法: ?*/? ? public static void? main(String[] arges)? ? {? ??? tree t = new tree();? ??? t.print("描述一棵樹:");? ??? t.print("樹根:");? ??? t.root();? ??? t.print("樹干:");? ??? t.bolo();? ??? t.print("樹枝:");? ??? t.branch();? ??? t.print("樹葉:");? ??? t.leaf();? ? }? }? /** ?* Title: 柳樹參數 ?* Description: 描述柳樹的參數 ?*/? class osier extends tree? {? ?/** ?*方法說明:過載樹的樹葉 ?*/? ? public void leaf()? ? {? ??? super.leaf();? ??? String sShape = "長形";? ??? super.print("形狀:"+sShape);? ? }? ? /** ?*方法說明:擴展樹的花 ?*/? ? public void flower()? ? {? ??? print("哈哈,柳樹沒有花!!");? ? }? /** ?*方法說明:主方法 ?*/? ? public static void? main(String[] args)? ? {? ??? osier o = new osier();? ??? o.print("柳樹樹根:");? ??? o.root();? ??? o.print("柳樹樹干:");? ??? o.bolo();? ??? o.print("柳樹樹枝:");? ??? o.branch();? ??? o.print("柳樹樹葉:");? ??? o.leaf();? ??? o.print("柳樹花:");? ??? o.flower();? ? }? }?
package test7;? ? /** ?*? Title:? 接口和抽象函數? ?*? Description: 演示繼承抽象函數和實現接口? ?*? Filename: newPlay.java ?*/? ?? //接口?? interface player? {? ?int flag = 1;? ?void play();//播放? ?void pause();//暫停? ?void stop();//停止? }//end :)? ? //抽象類? abstract class playing? {? ?public void display(Object oPara)? ?{? ?? System.out.println(oPara);??? ?}? ?abstract void winRun();? }//end :)? ? //繼承了playing抽象類和實現類player接口? public class newPlay extends playing implements player? {? ? public void play()? ? {? ??? display("newPlay.play()");//這里只是演示,去掉了代碼。? ? }? ? public void pause()? ? {? ???? display("newPlay.pause()");//這里只是演示,去掉了代碼。? ? }? ? public void stop()? ? {? ??? display("newPlay.stop()");//這里只是演示,去掉了代碼。? ? }? ? void winRun()? ? {? ??? display("newPlay.winRun()");//這里只是演示,去掉了代碼。? ? }? ? public static void main(String[] args)? ? {? ??? newPlay p = new newPlay();? ??? p.play();? ??? p.pause();? ??? p.stop();? ??? p.winRun();? ? }? }//end :)?
package test8.com;? ? /** ?* Title: 標識符 ?* Description: 演示標識符對類的訪問控制 ?* Filename: ?*/? public class classDemo1 {? ??? // 公有方法? ??? public void mechod1() {? ??????? System.out.println("這是一個公有的方法!任何類都可以訪問。");? ??? }? ? ??? // 授保護的方法? ??? protected void mechod2() {? ??????? System.out.println("這是一個受到保護的方法!只有子類可以訪問。");? ??? }? ? ??? // 私有的方法? ??? private void mechod3() {? ??????? System.out.println("這是一個私有的方法!只有類本身才可以訪問。");? ??? }? ? ??? public static void main(String[] args) {? ??????? classDemo1 d = new classDemo1();? ??????? d.mechod1();? ??????? d.mechod2();? ??????? d.mechod3();? ??? }? }?
package test8.com;? /** ?* Title: 標識符 ?* Description: 演示標識符對類的訪問控制 ?* Filename:? ?*/? public class classPlay? {? ? public static void main(String[] args){? ??? classDemo1 d = new classDemo1();? ??? d.mechod1();? ??? d.mechod2();? ??? //d.mechod3();? ? }? }?
package test8.net;? ? import test8.com.classDemo1;? /** ?* Title: 標識符 ?* Description: 演示標識符對類的訪問控制 ?* Filename:? ?*/? public class classPlay? {? ? public static void main(String[] args){? ??? classDemo1 d = new classDemo1();? ??? d.mechod1();? ? //d.mechod2();? ? //d.mechod3();? ? }? }?
package test9;? ? /** ?* Title: 捕獲異常和實現自己的異常 ?* Description: 通過繼承Exception類來實現自己的異常類。并使用try-catch來捕獲這個異常。 ?* Filename: ?*/? class MyException extends Exception {? ??? private static final long serialVersionUID = 1L;? ? ??? public MyException() {? ??? }? ? ??? public MyException(String msg) {? ??????? super(msg);? ??? }? ? ??? public MyException(String msg, int x) {? ??????? super(msg);? ??????? i = x;? ??? }? ? ??? public int val() {? ??????? return i;? ??? }? ? ??? private int i;? }? ? public class DemoException {? ??? /** ???? *方法說明:使用MyException類中默認的構造器 ???? */? ??? public static void a() throws MyException {? ??????? System.out.println("Throwing MyException from a()");? ??????? throw new MyException();? ??? }? ? ??? /** ???? *方法說明:使用MyException類中帶信息的構造器 ???? */? ??? public static void b() throws MyException {? ??????? System.out.println("Throwing MyException from b()");? ??????? throw new MyException("Originated in b()");? ??? }? ? ??? /** ???? *方法說明:使用了MyException中有編碼的構造器 ???? */? ??? public static void c() throws MyException {? ??????? System.out.println("Throwing MyException from c()");? ??????? throw new MyException("Originated in c()", 47);? ??? }? ? ??? public static void main(String[] args) {? ??????? try {? ??????????? a();? ??????? } catch (MyException e) {? ??????????? e.getMessage();? ??????? }? ??????? try {? ??????????? b();? ??????? } catch (MyException e) {? ??????????? e.toString();? ??????? }? ??????? try {? ??????????? c();? ??????? } catch (MyException e) {? ??????????? e.printStackTrace();? ??????????? System.out.println("error code: " + e.val());? ??????? }? ??? }? } // end :)?
package test10;? ? import javax.swing.*;? import java.awt.*;? ? /** ?* Title: 創建自己的窗體? ?* Description:? ?* Filename:mainFrame.java ?*/? public class mainFrame extends JFrame {? ? ??? private static final long serialVersionUID = 1L;? ? ??? /** ???? *方法說明:構造器,通過傳遞參數來完成窗體的繪制。? ???? *輸入參數:String sTitle 窗體標題? ???? *輸入參數:int iWidth 窗體的寬度 ???? *輸入參數:int iHeight 窗體的高度 返回類型: ???? */? ??? public mainFrame(String sTitle, int iWidth, int iHeight) {? ??????? Dimension dim = Toolkit.getDefaultToolkit().getScreenSize();// 獲取屏幕尺寸? ??????? ImageIcon ii = new ImageIcon("middle.gif");? ??????? setTitle(sTitle);// 設置窗體標題? ??????? setIconImage(ii.getImage());// 設置窗體的圖標? ??????? setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);// 設置但關閉窗體時退出程序? ??????? setSize(iWidth, iHeight);// 設置窗體大小? ??????? int w = getSize().width;// 獲取窗體寬度? ??????? int h = getSize().height;// 獲取窗體高度? ??????? System.out.println("窗體寬:" + w + " 窗體高:" + h);? ??????? int x = (dim.width - w) / 2;? ??????? int y = (dim.height - h) / 2;? ??????? setLocation(x, y);// 將窗體移到屏幕中間? ??????? setVisible(true);// 顯示窗體? ??? }? ? ??? public static void main(String[] args) {? ??????? JFrame.setDefaultLookAndFeelDecorated(true);// 使用最新的SWING外觀? ??????? new mainFrame("main Frame Demo", 400, 300);? ??? }? }?
?
轉載于:https://www.cnblogs.com/BuleSky001/p/7635293.html
總結
- 上一篇: 安装nginx及依赖包
- 下一篇: docker容器相关