三羊獻瑞——第六屆藍橋杯C語言B組(省賽)第三題

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

原創 三羊獻瑞 觀察下麵的加法算式: 祥 瑞 生 輝 + 三 羊 獻 瑞 三 羊 生 瑞 氣 (如果有對齊問題,可以參看【圖1.jpg】) 其中,相同的漢字代表相同的數字,不同的漢字代表不同的數字。 請你填寫“三羊獻瑞”所代表的4位數字(答案唯一),不要填寫任何多餘內容。 分析:三羊生瑞氣這個數中三 ...


原創


三羊獻瑞

觀察下麵的加法算式:

    祥 瑞 生 輝
 + 三 羊 獻 瑞
 -------------------
三 羊 生 瑞 氣

(如果有對齊問題,可以參看【圖1.jpg】)

其中,相同的漢字代表相同的數字,不同的漢字代表不同的數字。

請你填寫“三羊獻瑞”所代表的4位數字(答案唯一),不要填寫任何多餘內容。

分析:三羊生瑞氣這個數中只能是數位1,所以其他7個數字不必考慮是1

法一(枚舉):

枚舉祥、瑞、生、輝、羊、獻、氣這7個字,然後判斷是否滿足等式即可。

public class 三羊獻瑞 {
    public static void main(String args[]) {
        int tt=0;
        int arr[]=new int[7];
        for(arr[0]=2;arr[0]<=9;arr[0]++) {    //
            for(arr[1]=0;arr[1]<=9;arr[1]++) {    //
                if(arr[1]==1) {
                    continue;
                }
                for(arr[2]=0;arr[2]<=9;arr[2]++) {    //
                    if(arr[2]==1) {
                        continue;
                    }
                    for(arr[3]=0;arr[3]<=9;arr[3]++) {    //
                        if(arr[3]==1) {
                            continue;
                        }
                        for(arr[4]=0;arr[4]<=9;arr[4]++) {    //
                            if(arr[4]==1) {
                                continue;
                            }
                            for(arr[5]=0;arr[5]<=9;arr[5]++) {    //
                                if(arr[5]==1) {
                                    continue;
                                }
                                for(arr[6]=0;arr[6]<=9;arr[6]++) {    //
                                    if(arr[6]==1) {
                                        continue;
                                    }
                                    int flag[]= {0,0,0,0,0,0,0,0,0,0};
                                    int i=0;
                                    int ff=0;
                                    for(i=0;i<=6;i++) {    //判斷是否包含相同的數位
                                        if(flag[arr[i]]==1) {
                                            ff=1;
                                            break;
                                        }
                                        flag[arr[i]]=1;
                                    }
                                    if(ff==1) {    //有相同數位
                                        continue;
                                    }
                                    if((arr[0]*1000+arr[1]*100+arr[2]*10+arr[3])+(1000+arr[4]*100+arr[5]*10+arr[1])==10000+arr[4]*1000+arr[2]*100+arr[1]*10+arr[6]) {
                                        System.out.println(1000+arr[4]*100+arr[5]*10+arr[1]);
                                        tt=1;
                                    }
                                    if(tt==1) {
                                        break;
                                    }
                                }
                                if(tt==1) {
                                    break;
                                }
                            }
                            if(tt==1) {
                                break;
                            }
                        }
                        if(tt==1) {
                            break;
                        }
                    }
                    if(tt==1) {
                        break;
                    }
                }
                if(tt==1) {
                    break;
                }
            }
            if(tt==1) {
                break;
            }
        }
    }
}

法二(全排列):

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

0、2、3、4、5、6、7、8、9這8個數位進行全排列,每產生一種全排列就將全排列前7

位數取出進行運算,滿足條件算式輸出即可。

public class 三羊獻瑞{
    static int flag=0;
    static int arr[]= {0,2,3,4,5,6,7,8,9};
    static void Swap(int a,int b) {
        int temp=0;
        temp=arr[a];
        arr[a]=arr[b];
        arr[b]=temp;
    }
    static void Quan(int num) {
        if(num==8) {    //產生一種全排列
            if((arr[0]*1000+arr[1]*100+arr[2]*10+arr[3])+(1000+arr[4]*100+arr[5]*10+arr[1])==10000+arr[4]*1000+arr[2]*100+arr[1]*10+arr[6]) {
                System.out.println(1000+arr[4]*100+arr[5]*10+arr[1]);
                flag=1;
            }
            return;
        }
        int i=0;
        for(i=num;i<=8;i++) {
            Swap(i,num);
            Quan(num+1);
            if(flag==1) {
                return;
            }
            Swap(i,num);
        }
    }
    public static void main(String args[]) {
        Quan(0);
    }
}

答案:1085

22:07:35

2018-06-08


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

-Advertisement-
Play Games
更多相關文章
  • ref:https://blog.csdn.net/wuxiaobingandbob/article/details/78642020?fps=1&locationNum=1 http://www.cnblogs.com/imyalost/p/6792724.html http://www.cnbl ...
  • wframe不是控制項庫,也不是UI庫,她是一個微信小程式面向對象編程框架,代碼只有幾百行。她的主要功能是規範小程式項目的文件結構、規範應用程式初始化、規範頁面載入及授權管理的框架,當然,wframe也提供了一些封裝好了的函數庫,方便開發者調用。 wframe目前已實現的核心功能: 1. 應用程式初始 ...
  • define和typedef的區別 define是單純的字元替換,typedef是重新定義了新的類型 ...
  • Java面向對象的三大特性之繼承一:繼承的概念;二:類的繼承格式;三:為什麼需要繼承;四:繼承的特性;五:繼承的關鍵字; ...
  • def func1(seq1): dic={ 'num':0, 'string':0, 'space':0, 'other':0 } for line in seq1: if line.isdigit(): dic['num'] += 1 elif line.isalpha(): dic['stri ...
  • Java中的內部類一:什麼是內部類;二:Java 中的成員內部類;三:Java 中的靜態內部類;四:Java 中的方法內部類; ...
  • 就是想記錄一下 JSP中傳參的四種方法: 1、form表單 2、request.setAttribute();和request.getAttribute(); 3、超鏈接:<a herf="index.jsp"?a=a&b=b&c=c>name</a> 4、<jsp:param> 發生Referen ...
  • python從2.6開始支持format,新的更加容易讀懂的字元串格式化方法, 從原來的% 模式變成新的可讀性更強的 綜合舉例說明: 輸入: '{:>18,.2f}'.format(70305084.0) # :冒號+空白填充+右對齊+固定寬度18+浮點精度.2+浮點數聲明f 輸出:' 70,305 ...
一周排行
    -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# ...