編程題以及答案

【程序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=233*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】
題目:輸入一行字符,分別統計出其中英文字母、空格、數字和其它字符的個數。

import java.util.*;
public class lianxi07 {
	public static void main(String[] args) {
	int digital = 0;
	int character = 0;
	int other = 0;
	int blank = 0;
	     char[] ch = null;
	     Scanner sc = new Scanner(System.in);
	     String s = sc.nextLine();
	     ch = s.toCharArray();
	     for(int i=0; i<ch.length; i++) {
	      if(ch >= '0' && ch <= '9') {
	       digital ++;
	      } else if((ch >= 'a' && ch <= 'z') || ch > 'A' && ch <= 'Z') {
	       character ++;
	      } else if(ch == ' ') {
	       blank ++;
	      } else {
	       other ++;
	      }
	      }
	     System.out.println("數字個數: " + digital);
	     System.out.println("英文字母個數: " + character);
	     System.out.println("空格個數: " + blank);
	     System.out.println("其他字符個數:" + other );
	}
	}
	```
	
	【程序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 = 100;
      for(int i=1; i<10; i++) {
      s = s + h;
      h = h / 2;
     }
     System.out.println("經過路程:" + s);
     System.out.println("反彈高度:" + h / 2);
}
} 

【程序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+268) % 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】
題目:一個多爲整數,判斷它是不是迴文數。即12321是迴文數,個位與萬位相同,十位與千位相同。

//這個更好,不限位數
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;
     }
    }
   }
  System.out.println(Arrays.toString(a));
}
}

【程序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個數

public void test14() {
		int N = 10;
		Scanner scn = new Scanner(System.in);
		System.out.println("請輸入10個整數:");
		int[] a = new int[N]; 
		for(int i=0; i<N; i++) { 
			a[i] = scn.nextInt();
		}
		System.out.println("你輸入的數組爲:" + Arrays.toString(a));
		System.out.println("請輸入向後移動的位數:");
		int m = scn.nextInt();
		int[] b = new int[N + m];
		for (int i = 0; i < N; i++) {
			b[m + i] = a[i];
		}
		System.out.println("向後移動" + m + "位數爲:" + Arrays.toString(b));
		for (int i = 0; i < m; i++) {
			b[i] = a[N - m + i];
		}
		System.out.println("後面" + m + "位數放到前面爲:" + Arrays.toString(b));
		System.arraycopy(b, 0, a, 0, a.length);
		System.out.println("位移後的數組a爲:" + Arrays.toString(a));
		scn.close();
}

【程序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;
   }
   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位數是74個。
//組成3位數是7
84個。
//組成4位數是7
884個。
//…

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(); 
     } 
}
}

【程序51】編寫java程序,將以下字符串:“0012,x388w,w89|73|87x234,23238uy,7893,23|2|34,1”按照“,”進行換行,每一個分隔符(“,”或“|”)間的字符串不夠6爲在左側補“0”,超出6位截取掉右側超出部分,將“|”替換成“&”

public void test9() {
		String str = "0012,x388w,w89&73&87x234,23238uy,7893,23&2&34,1";
		if( str.indexOf(",")!=-1 ) {
			String[] str1 = str.split(",");
			for( int j=0; j<str1.length; j++ ) {
				if( str1[j].length() == 6 ) {
					if( str1[j].indexOf("&") !=-1 ) {
						String[] str2 = str1[j].split("&");
						splitStr(str2);
					}else {
						System.out.print( str1[j] +"   " );
					}
				}else if( str1[j].length() < 6 ) {
					if( str1[j].indexOf("&") !=-1 ) {
						String[] str2 = str1[j].split("&");
						splitStr(str2);
					}else {
						String strk1 = "";
						for( int g=0;g<(6-str1[j].length()); g++ ) {
							strk1 += "0";
						}
						str1[j] = strk1+str1[j];
						System.out.print( str1[j] +"   " );
					}
				}else if( str1[j].length() > 6 ) {
					if( str1[j].indexOf("&") !=-1 ) {
						String[] str2 = str1[j].split("&");
						splitStr(str2);
					}else {
						str1[j] = str1[j].substring(0, 6 );
						System.out.print( str1[j] +"   " );
					}
				}
				System.out.println();
			}
		}
	}
	public void splitStr(String[] str2) {
		for( int k=0; k<str2.length; k++ ) {
			if( str2[k].length() == 6 ) {
				str2[k] = str2[k];
				System.out.print( str2[k] +"   " );
			}else if( str2[k].length() < 6 ) {
				String strk1 = "";
				for( int g=0;g<(6-str2[k].length()); g++ ) {
					strk1 += "0";
				}
				str2[k] = (strk1+str2[k]);
				System.out.print( str2[k] +"   " );
			}else if( str2[k].length() > 6 ) {
				str2[k] = str2[k].substring(0, 6 );
				System.out.print( str2[k] +"   " );
			}
		}
	}

【程序52】編寫java程序,首先讀入集合A{12,1,13,11,9,10,9,8,7,2,1,3,6,4}和集合B{9,1,3,2,8,7,12,11,6}
1.計算集合AB的交集
2.按從大到小的順序排序集合A

public void test10() {
		System.out.println( "1.計算集合AB的交集" );
		Integer[] arrA = {12,1,13,11,9,10,9,8,7,2,1,3,6,4};
		Integer[] arrB = {9,1,3,2,8,7,12,11,6};
		List<Integer> listA = new ArrayList<Integer>(); 
		List<Integer> listB = new ArrayList<Integer>(); 
		List<Integer> listC = new ArrayList<Integer>();
		for( int i=0; i<arrA.length; i++ ) {
			listA.add( arrA[i] );
		}
		for( int i=0; i<arrB.length; i++ ) {
			listB.add( arrB[i] );
		}
		System.out.println( "listA="+listA );
		System.out.println( "listB="+listB );
		for( int i=0; i<listA.size(); i++ ) {
			for( int j=0; j<listB.size(); j++ ) {
				if( listA.get(i) == listB.get(j) ) {
					listC.add( listA.get(i) );
				}
			}
		}
		System.out.println( "沒有去除重複的交集:listC="+listC );
		/*如果要去除集合重複部分*/
		List<Integer> newListC = new  ArrayList<Integer>(); 
		for (Integer cd:listC) {
			if(!newListC.contains(cd)){
				newListC.add(cd);
            }
		}
		System.out.println( "去除重複後的交集:newListC="+newListC );
		System.out.println(  );
		System.out.println( "2.按從大到小的順序排序集合A" );
		Collections.sort(listA);
		System.out.println( "集合A排序但是沒有去除重複數據:listA="+listA );
		/*去除排序集合A中重複數據*/
		List<Integer> newListA = new  ArrayList<Integer>(); 
		for (Integer cd:listA) {
			if(!newListA.contains(cd)){
				newListA.add(cd);
            }
		}
		System.out.println( "集合A排序並且去除重複數據:listA="+newListA );
	}

【程序53】將集合中的標題好按樹形結構輸出,如給定集合
* {1,2,3,1.1,2.1,3.1,3.2,3.3,2.1.1,3.2.1,3.2.1.1}輸出

public void test11() {
		String[] arr = {"1","2","3","1.1","2.1","3.1","3.2","3.3","2.1.1","3.2.1","3.2.1.1"};
		List<String> list = new ArrayList<String>();
		for( int i=0; i<arr.length; i++ ) {
			list.add( arr[i] );
		}
		Collections.sort(list);
		for( int i=0; i<list.size(); i++ ) {
			if( list.get(i).length() == 1 ) {
				System.out.print( list.get(i) + "\n");
			}else if( list.get(i).length() == 3 ){
				System.out.print( " "+list.get(i) + "\n");
			}else if( list.get(i).length() == 5 ){
				System.out.print( "  "+list.get(i) + "\n");
			}else if( list.get(i).length() == 7 ){
				System.out.print( "   "+list.get(i) + "\n");
			}
		}
	}

【程序54】
遞歸變量 D盤下的所有文件和文件夾

private static AtomicInteger count = new AtomicInteger(0);//記錄所有文件
	@Test
	public void test13() throws Exception {
		//取得目標目錄
        File file1 = new File("F:");
        //獲取目錄下子文件及子文件夾
        File[] files = file1.listFiles();
        File file2 = new File("F:");
        readFile(file2);
        System.out.printf("文件總量:" + count);
	}
	public static void readFile(File file) {
        File[] fileList = file.listFiles();
        if (fileList == null) {
            return;
        }
        for (File f : fileList) {
            if (f.isFile()) {
                count.incrementAndGet();
                System.out.println("文件名:" + f.getName());
            }
            if (f.isDirectory()) {
                readFile(f);
            }
        }
    }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章