欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java編程實現(xiàn)求解八枚銀幣代碼分享

 更新時間:2017年11月30日 17:10:53   作者:ljtyzhr  
這篇文章主要介紹了java編程實現(xiàn)求解八枚銀幣代碼分享,具有一定參考價值,需要的朋友可以了解下。

1、引言

筆者在大學的算法競賽中,遇到過這樣的一個題目,現(xiàn)在拿出來與大家分享一下:現(xiàn)在有現(xiàn)有八枚銀幣abcdefgh,已知其中一枚是假幣,其重量不同于真幣,但不知是較輕或較重,如何使用天平以最少的比較次數(shù),決定出哪枚是假幣,并得知假幣比真幣較輕或較重。

2、分析

如果本題目只是很單純的求解假幣是哪一個,問題倒并不是很復雜,只需要回溯遞歸便可求得結果。問題的難點在意,我們需要用最少的步驟?。?!

比之以前的數(shù)據(jù)結構問題,有遞歸,回溯,我們今天可能要接觸一個新的概念,叫做樹。顧名思義,數(shù)結構就是說我們的分析圖示像樹一樣,有分支節(jié)點等各種信息。樹結構是數(shù)據(jù)結構中的一個較大的章節(jié),不在我們的討論之中,在本題目當中,我們會介紹樹的一個小小的分子,決策樹。

我們先建立一下,八個銀幣求解的數(shù)學模型。一個簡單的狀況是這樣的,我們將銀幣依次命名為abcdefg等,我們比較a+b+c與d+e+f,如果相等,則假幣必是g或h,我們先比較g或h哪個較重,如果g較重,再與a比較(a是真幣),如果g等于a,則g為真幣,則h為假幣,由于h比g輕而g是真幣,則h假幣的重量比真幣輕。

如果不相等呢?又是何種情況,我們將依次分支回溯比較,直到得到最終的答案!

3、示例圖

根據(jù)上面的分析,我們可以有一個完整的決策樹圖示:

4、代碼

public class Coins { 
  private int[] coins; 
   
  public Coins() { 
    coins = new int[8]; 
    for(int i = 0; i < 8; i++)  
      coins[i] = 10;  
  } 
   
  public void setFake(int weight) { 
    coins[(int) (Math.random() * 7)] = weight; 
  } 
   
  public void fake() { 
    if(coins[0]+coins[1]+coins[2] ==  
      coins[3]+coins[4]+coins[5]) {  
      if(coins[6] > coins[7])  
        compare(6, 7, 0);  
      else  
        compare(7, 6, 0);  
    }  
    else if(coins[0]+coins[1]+coins[2] >  
        coins[3]+coins[4]+coins[5]) {  
      if(coins[0]+coins[3] == coins[1]+coins[4])  
        compare(2, 5, 0);  
      else if(coins[0]+coins[3] > coins[1]+coins[4])  
        compare(0, 4, 1);  
      if(coins[0]+coins[3] < coins[1]+coins[4])  
        compare(1, 3, 0);  
    }  
    else if(coins[0]+coins[1]+coins[2] <  
        coins[3]+coins[4]+coins[5]) {  
      if(coins[0]+coins[3] == coins[1]+coins[4])  
        compare(5, 2, 0);  
      else if(coins[0]+coins[3] > coins[1]+coins[4])  
        compare(3, 1, 0);  
      if(coins[0]+coins[3] < coins[1]+coins[4])  
        compare(4, 0, 1);  
    }  
  } 
   
  protected void compare(int i, int j, int k) { 
    if(coins[i] > coins[k])  
      System.out.print("\n假幣 " + (i+1) + " 較重");  
    else  
      System.out.print("\n假幣 " + (j+1) + " 較輕");  
  } 
   
  public static void main(String[] args) { 
    if(args.length == 0) { 
      System.out.println("輸入假幣重量(比10大或?。?); 
      System.out.println("ex. java Coins 5"); 
      return; 
    } 
     
    Coins eightCoins = new Coins(); 
    eightCoins.setFake(Integer.parseInt(args[0])); 
    eightCoins.fake(); 
  } 
} 

結果:

輸入假幣重量(比10大或小)
ex. java Coins 5

這里是一段通用的解題方法,大家可以仔細琢磨代碼,對于本段代碼,上面的分析已經(jīng)足夠,剩下的就要大家自己琢磨學習了,這樣才能深刻理解。

總結

以上就是本文關于java編程實現(xiàn)求解八枚銀幣代碼分享的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

相關文章

  • 一文帶你掌握SpringBoot中常見定時任務的實現(xiàn)

    一文帶你掌握SpringBoot中常見定時任務的實現(xiàn)

    這篇文章主要為大家詳細介紹了Spring?Boot中定時任務的基本用法、高級特性以及最佳實踐,幫助開發(fā)人員更好地理解和應用定時任務,提高系統(tǒng)的穩(wěn)定性和可靠性,需要的可以參考下
    2024-03-03
  • Spring MVC訪問靜態(tài)文件_動力節(jié)點Java學院整理

    Spring MVC訪問靜態(tài)文件_動力節(jié)點Java學院整理

    這篇文章主要為大家詳細介紹了Spring MVC訪問靜態(tài)文件的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Lombok插件的安裝與簡單使用步驟

    Lombok插件的安裝與簡單使用步驟

    這篇文章主要介紹了Lombok插件的安裝與簡單使用步驟,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • Java 實戰(zhàn)項目之倉庫管理系統(tǒng)的實現(xiàn)流程

    Java 實戰(zhàn)項目之倉庫管理系統(tǒng)的實現(xiàn)流程

    讀萬卷書不如行萬里路,只學書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+SSM+jsp+mysql+maven實現(xiàn)一個倉庫管理系統(tǒng),大家可以在過程中查缺補漏,提升水平
    2021-11-11
  • java中如何對Map的key順序排序

    java中如何對Map的key順序排序

    大家都知道Map排序的方式有很多種,下面這篇文章主要給大家介紹了關于java中如何對Map的key順序排序的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-11-11
  • 使用@JsonFormat的一個坑及解決

    使用@JsonFormat的一個坑及解決

    這篇文章主要介紹了使用@JsonFormat的一個坑及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java中Object用法詳解

    Java中Object用法詳解

    Java是面向對象的編程語言,而在面向對象中,所有的Java類都有一個共同的祖先類,這就是Object,那么Object都有哪些特性呢?今天小編就簡單跟大家分析一下,感興趣的同學可以跟著小編一起學習
    2023-05-05
  • 多線程死鎖的產(chǎn)生以及如何避免死鎖方法(詳解)

    多線程死鎖的產(chǎn)生以及如何避免死鎖方法(詳解)

    下面小編就為大家?guī)硪黄嗑€程死鎖的產(chǎn)生以及如何避免死鎖方法(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • Java 值傳遞和引用傳遞詳解及實例代碼

    Java 值傳遞和引用傳遞詳解及實例代碼

    這篇文章主要介紹了 Java 值傳遞和引用傳遞詳解及實例代碼的相關資料,需要的朋友可以參考下
    2017-03-03
  • IDEA 2020代碼提示忽略大小寫的問題

    IDEA 2020代碼提示忽略大小寫的問題

    這篇文章主要介紹了IDEA 2020代碼提示忽略大小寫的問題,本文通過圖文并茂的形式給大家分享解決方法,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07

最新評論