1. 程式人生 > 其它 >Day22---學習Java第三彈

Day22---學習Java第三彈

2021-08-01

Java經典程式設計例題(六)

17、題目:企業發放的獎金根據利潤提成。利潤(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 test {
 public static void main (String[]args){
double sum;//宣告要儲存的變數應發的獎金 Scanner input =new Scanner (System.in);//匯入掃描器 System.out.print ("輸入當月利潤"); double lirun=input .nextDouble();//從控制檯錄入利潤 if(lirun<=100000){ sum=lirun*0.1; }else if (lirun<=200000){ sum=10000+lirun*0.075; }else if (lirun<=400000){ sum=17500+lirun*0.05; }else if (lirun<=600000){ sum=lirun*0.03; }else if
(lirun<=1000000){ sum=lirun*0.015; } else{ sum=lirun*0.01; } System.out.println("應發的獎金是"+sum); } }

程式分析:請利用數軸來分界,定位。注意定義時需把獎金定義成長整型。

18、題目:輸入某年某月某日,判斷這一天是這一年的第幾天?

import java.util.*; 
public class test { 
public static void main (String[]args){
 int day=0; 
int month=0;
 int year=0; 
int sum=0;
 int leap;
System.out.print(
"請輸入年,月,日\n"); Scanner input = new Scanner(System.in); year=input.nextInt(); month=input.nextInt(); day=input.nextInt(); switch(month) /*先計算某月以前月份的總天數*/ {case 1: sum=0;break; case 2: sum=31;break; case 3: sum=59;break; case 4: sum=90;break; case 5: sum=120;break; case 6: sum=151;break; case 7: sum=181;break; case 8: sum=212;break; case 9: sum=243;break; case 10: sum=273;break; case 11: sum=304;break; case 12: sum=334;break; default: System.out.println("data error");break; } sum=sum+day; /*再加上某天的天數*/ if(year%400==0||(year%4==0&&year%100!=0))/*判斷是不是閏年*/ elseleap=1; leap=0; if(leap==1 && month>2)/*如果是閏年且月份大於2,總天數應該加一天*/ sum++; System.out.println("It is the the day:"+sum); } }


程式分析:以3月5日為例,應該先把前兩個月的加起來,然後再加上5天即本年的第幾天,特殊情況,閏年且輸入月份大於3時需考慮多加一天。

19、題目:輸入三個整數x,y,z,請把這三個數由小到大輸出。

import java.util.*; public class test { public static void main (String[]args){ int i=0; int j=0; int k=0; int x=0;
System.out.print("請輸入三個數\n");
Scanner input = new Scanner(System.in);
i=input.nextInt();
j=input.nextInt();
k=iifnput.nextInt(); (i>j)
{
x=i;
i=j;
j=x;
}if(i>k)
{
x=i;
i=k;
k=x;
}if(j>k)
{
x=j;
j=k;
k=x;
}
System.out.println(i+", "+j+", "+k);
}
}

程式分析:我們想辦法把最小的數放到x上,先將x與y進行比較,如果x> y則將x與y的值進行交換,

然後再用x與z進行比較,如果x> z則將x與z的值進行交換,這樣能使x最小。