Java黑皮书课后题第6章:*6.5(对三个数排序)使用下面的方法头编写方法,按升序显示三个数
*6.5(對(duì)三個(gè)數(shù)排序)使用下面的方法頭編寫(xiě)方法,按升序顯示三個(gè)數(shù)
- 題目
- 題目概述
- 破題
- 代碼:排序
- 運(yùn)行結(jié)果
題目
題目概述
*6.5(對(duì)三個(gè)數(shù)排序)使用下面的方法頭編寫(xiě)方法,按升序顯示三個(gè)數(shù):
public static void displaySortedNumbers(double num1, double num2, double num3)
編寫(xiě)程序,提示用戶輸入3個(gè)數(shù)字,調(diào)用方法以升序顯示它們
破題
第一種方法:Math.max(a, b)
在方法displaySortedNumbers中對(duì)三個(gè)數(shù)字調(diào)用Math.max()方法
如Math.max(num1, Math.max(num2, num3))得出最大值并在方法內(nèi)輸出
再比較剩下兩個(gè)數(shù),分別輸出即可
(因?yàn)榉椒^有void,主方法只調(diào)用不輸出,displaySortedNumbers()方法return;)
第二種方法:借助排序算法
如果num1>num2則調(diào)換兩個(gè)值(僅互換值)
如果num1>num3則調(diào)換兩個(gè)值(僅互換值)
如果num2>num3則調(diào)換兩個(gè)值(僅互換值)
最后依次輸出num1 num2 num3即可
但特別注意:兩個(gè)double型數(shù)值由于存在誤差,上面的比較大小可以換成:
num1 - num2 > 0.0001
num1 - num3 > 0.0001
num2 - num3 > 0.0001
代碼:排序
import java.util.Scanner;public class Test6_5 {public static void main(String[] args) {// 接收用戶輸入的三個(gè)double型數(shù)Scanner input = new Scanner(System.in);System.out.print("輸入三個(gè)數(shù)字(double):");double num1 = input.nextDouble(), num2 = input.nextDouble(), num3 = input.nextDouble();// 調(diào)用方法displaySortedNumbers()displaySortedNumbers(num1, num2, num3);}public static void displaySortedNumbers(double num1, double num2, double num3){// 排序double temp = 0; // 臨時(shí)保存變量if (num1 > num2){temp = num1;num1 = num2;num2 = temp;}if (num1 > num3){temp = num1;num1 = num3;num3 = temp;}if (num2 > num3){temp = num2;num2 = num3;num3 = temp;}// 輸出System.out.print(num1 + " " + num2 + " " + num3);return;} }運(yùn)行結(jié)果
輸入三個(gè)數(shù)字(double):3 1 2 1.0 2.0 3.0 Process finished with exit code 0總結(jié)
以上是生活随笔為你收集整理的Java黑皮书课后题第6章:*6.5(对三个数排序)使用下面的方法头编写方法,按升序显示三个数的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Java黑皮书课后题第6章:*6.4(反
- 下一篇: Java黑皮书课后题第6章:*6.6(显