湊算式——第七屆藍橋杯C語言B組(省賽)第三題

来源:https://www.cnblogs.com/chiweiming/archive/2018/06/07/9152722.html
-Advertisement-
Play Games

原創 湊算式 B DEFA + + = 10 C GHI (如果顯示有問題,可以參見【圖1.jpg】) 這個算式中A~I代表1~9的數字,不同的字母代表不同的數字。 比如:6+8/3+952/714 就是一種解法,5+3/1+972/486 是另一種解法。 這個算式一共有多少種解法? 註意:你提交應 ...


原創


湊算式

       B      DEF
A + --- + ------- = 10
       C      GHI

(如果顯示有問題,可以參見【圖1.jpg】)

這個算式中A~I代表1~9的數字,不同的字母代表不同的數字。

比如:
6+8/3+952/714 就是一種解法,
5+3/1+972/486 是另一種解法。

這個算式一共有多少種解法?

註意:你提交應該是個整數,不要填寫任何多餘的內容或說明性文字。

法一(枚舉):

開闢9個變數分別代表1~9個數,每個變數在1~9中變化,對於每一個數字都判斷是否包含1~9個數位和滿足湊算式即可。

public class 湊算式 {
    public static void main(String args[]) {
        double arr[]=new double[9];
        long total=0L;
        for(arr[0]=1;arr[0]<=9;arr[0]++) {
            for(arr[1]=1;arr[1]<=9;arr[1]++) {
                for(arr[2]=1;arr[2]<=9;arr[2]++) {
                    for(arr[3]=1;arr[3]<=9;arr[3]++) {
                        for(arr[4]=1;arr[4]<=9;arr[4]++) {
                            for(arr[5]=1;arr[5]<=9;arr[5]++) {
                                for(arr[6]=1;arr[6]<=9;arr[6]++) {
                                    for(arr[7]=1;arr[7]<=9;arr[7]++) {
                                        for(arr[8]=1;arr[8]<=9;arr[8]++) {
                                            int i=0;
                                            int tt=0;
                                            int flag[]=new int[10];
                                            for(i=0;i<=8;i++) {    //判斷是否包含0~9
                                                if(flag[(int)(arr[i])]==1) {
                                                    break;
                                                }
                                                flag[(int)(arr[i])]=1;
                                                tt++;
                                            }
                                            if(tt==9) {
                                                if(arr[0]+arr[1]/arr[2]+(arr[3]*100+arr[4]*10+arr[5])/(arr[6]*100+arr[7]*10+arr[8])==10) {
                                                    total++;
                                                }
                                            }
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
        System.out.println(total);
    }
}

法二(全排列):

全排列的思想請看我另外一篇博客:https://www.cnblogs.com/chiweiming/p/8727164.html

每產生一種全排列,就判斷是否滿足湊算式即可。

public class 湊算式{
    static int total=0;
    static int arr[]=new int[9];
    
    static void Swap(int a,int b) {    //交換
        int temp=0;
        temp=arr[a];
        arr[a]=arr[b];
        arr[b]=temp;
    }
    
    static void Full_Sort(int num) {    //全排列
        
        if(num==9) {    //產生一種全排列
            double a=arr[0];
            double b=arr[1];
            double c=arr[2];
            double def=arr[3]*100+arr[4]*10+arr[5];
            double ghi=arr[6]*100+arr[7]*10+arr[8];
            if(a+b/c+def/ghi==10) {
                total++;
            }
            return;
        }
        
        int i=0;
        for(i=num;i<=8;i++) {
            Swap(num,i);
            Full_Sort(num+1);
            Swap(num,i);
        }
    }
    
    public static void main(String args[]) {
        int i=0;
        for(i=0;i<=8;i++) {
            arr[i]=i+1;
        }
        Full_Sort(0);
        System.out.println(total);
    }
}

答案:29

21:10:02

2018-06-07


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Java面向對象的三大特性之封裝一:面向對象的三大特性;二:封裝的概念;三:封裝的好處;四:實現Java封裝的步驟; ...
  • 題目描述 給定一個字元串,要求把字元串前面的若幹個字元移動到字元串的尾部,如把字元串“abcdef”前面的2個字元'a'和'b'移動到字元串的尾部,使得原字元串變成字元串“cdefab”。請寫一個函數完成此功能,要求對長度為n的字元串操作的時間複雜度為 O(n),空間複雜度為 O(1)。 分析與解法 ...
  • 1.JDK中的Executor框架是基於生產者-消費者模式的線程池,提交任務的線程是生產者,執行任務的線程是消費者。 Executor線程池可以用於非同步任務執行,而且支持很多不同類型任務執行策略,同時為任務提交和任務執行之間的解耦提供了標準方法。 Executor線程池支持如下三種線程執行策略: ( ...
  • 在電腦科學中,二叉樹是每個結點最多有兩個子樹的樹結構。通常子樹被稱作“左子樹”(left subtree)和“右子樹”(right subtree)。二叉樹常被用於實現二叉查找樹和二叉堆。 ...
  • 需要先把Oracle包倒到項目中ojdbc14-10.2.0.1.0.jar ...
  • Description 我們講一個悲傷的故事。 從前有一個貧窮的樵夫在河邊砍柴。 這時候河裡出現了一個水神,奪過了他的斧頭,說: “這把斧頭,是不是你的?” 樵夫一看:“是啊是啊!” 水神把斧頭扔在一邊,又拿起一個東西問: “這把斧頭,是不是你的?” 樵夫看不清楚,但又怕真的是自己的斧頭,只好又答: ...
  • 我們提供一個初學者最好的Python書籍列表。Python是一個初級程式員可以學習編程的最友好語言之一。為了幫助您開始使用Python編程,我們分享此列表。泡一杯茶,選一本書閱讀,開始使用Python編程! Python編程:從入門到實踐 本書是一本針對所有層次的Python 讀者而作的Python ...
  • 棧: 對列: ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...