【c語言】整數拆分

来源:https://www.cnblogs.com/xxoy/archive/2023/03/09/17201151.html
-Advertisement-
Play Games

將一個正整數n拆分成若幹個正整數的和(至少兩個數,n<=100)。 輸入格式: 一個正整數n 輸出格式: 若幹行,每行一個等式(數與數之間要求非降序排列)。最後一行給出解的總個數 輸入樣例: 在這裡給出一組輸入。例如: 4 輸出樣例: 4=1+1+1+1 4=1+1+2 4=1+3 4=2+2 4 ...


將一個正整數n拆分成若幹個正整數的和(至少兩個數,n<=100)。

輸入格式:

一個正整數n

輸出格式:

若幹行,每行一個等式(數與數之間要求非降序排列)。最後一行給出解的總個數

輸入樣例:

在這裡給出一組輸入。例如:

4
 

輸出樣例:

4=1+1+1+1
4=1+1+2
4=1+3
4=2+2
4
 

最後一行的4表示總共有4個解。

 

主要思路: 使用深度優先搜索演算法。從n開始,每次枚舉所有可能的加數,如果加數滿足要求,則將其加入到組成部分中,繼續遞歸處理剩餘部分,直到剩餘部分被成功分解或者不滿足要求,然後回溯,撤銷當前加數的選擇,嘗試下一個加數。這樣就能夠窮舉所有可能的分解方案。 使用遞歸函數dfs()實現深度優先搜索。dfs()函數有三個參數:cur表示當前需要分解的數,sum表示已經分解的數之和,last表示上一個加數。當cur為0且sum為n時,找到了一個分解方案,將其輸出;否則,枚舉所有可能的加數,並對剩餘部分進行遞歸處理。 在dfs()函數中使用數組nums[]存儲每個組成部分的數值,使用變數size記錄當前組成部分的數量。在遞歸處理剩餘部分時,需要將當前加數加入組成部分,並遞歸處理剩餘部分,成功分解後回溯,撤銷當前加數的選擇。這裡使用回溯法可以避免重覆計算。

 

// 原作者箱庭,請勿轉載

#include <stdio.h>

int n;          // 待分解的數
int nums[100];  // 存儲每個組成部分的數值
int size;       // 當前組成部分的數量
int cnt;        // 分解方案的數量

// 深度優先搜索函數,cur為當前需要分解的數,sum為已分解的數之和,last為上一個加數
void dfs(int cur, int sum, int last) {
    // 如果已經成功分解出所有數且總和為n,則找到了一個分解方案
    if (cur == 0 && sum == n) {
        cnt++;  // 記錄分解方案的數量
        // 輸出分解方案
        printf("%d=%d", n, nums[0]);
        for (int i = 1; i < size; i++) {
            printf("+%d", nums[i]);
        }
        printf("\n");
    } else {
        // 枚舉所有可能的加數
        for (int i = 1; i <= cur; i++) {
            // 確保加數不小於上一個加數,總和不超過n,並且不能僅剩一個數未加入
            if (i >= last && sum + i <= n && i<n ) {
                nums[size] = i;  // 將當前加數存入組成部分
                size++;          // 組成部分數量加1
                dfs(cur - i, sum + i, i);  // 繼續分解剩餘部分
                size--;          // 回溯,撤銷當前加數的選擇
            }
        }
    }
}
//原作者箱庭,請勿轉載

int main() { scanf("%d", &n); // 輸入待分解的數 nums[0] = 0; // 初始化組成部分,第一個數為0 size = 0; // 初始化組成部分數量 dfs(n , 0, 1); // 開始分解 printf("%d", cnt); // 輸出分解方案數量 return 0; }

 


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

-Advertisement-
Play Games
更多相關文章
  • 前置知識: Web 伺服器:可以指硬體上的,也可以指軟體上的。從硬體的角度來說, Web 伺服器指的就是一臺存儲了網路服務軟體的電腦;從軟體的角度來說, Web 伺服器指的是一種軟體,比如 Tomcat。 Servlet 容器:目前主流的 Servlet 容器軟體包括 Tomcat、Jetty、J... ...
  • SpringBoot Controller 控制器 SpringBoot提供了@Controller和@RestController兩種註解來標識此類負責接收和處理HTTP請求。 如果請求的是頁面和數據,使用@Controller註解即可;如果只是請求數據,則可以使用@RestController註 ...
  • 1.學習目標 2.簡介 技術論壇:http://bbs.chinaunix.net/forum-240-1.html 資源地址:https://sourceforge.net/projects/fastdfs/ 源碼地址:https://github.com/happyfish100 FastDFS ...
  • 前言 對於大多數 maven 多模塊化工程,可以使用 Jacoco 這款工具,關於 Jacoco 這款工具,ChatGPT 對它的描述是這樣的: JaCoCo(Java Code Coverage)是一個開源的測試覆蓋率工具,它可以用於幫助開發人員衡量其軟體測試的有效性。它支持多種語言,包括 Jav ...
  • 1、Spring 1.1、簡介 Spring:春天 >給軟體行業帶來了春天! 2002,首次推出了Spring框架的雛形:interf21框架! Spring框架即以interface21框架為基礎,經過重新設計,並不斷豐富其內涵,於2004年3月24日發佈了1.0正式版。 Rod Johnson ...
  • 之前給大家寫過如何將 ChatGPT 接入微信和釘釘,沒看過的可以往公眾號前面的文章翻翻,最近又發現了一個有趣的玩法,周末找時間實現了一下,感覺挺不錯的,分享給大家。 背景 事情的起因是阿粉在朋友圈看到了這樣一條信息,敏感信息已經去掉了,意思很明顯就是將 OpenAI 接入到知識星球了,用戶可以通過 ...
  • Celery介紹、安裝、基本使用 一、Celery服務 什麼是Celery: Celery是一個簡單、靈活且可靠的,處理消息的分散式系統 Celery可以用來做什麼: 非同步任務 定時任務 延遲任務 Celery的運行原理: 可以不依賴任何服務,通過自身命令,啟動服務 celery服務為其他項目服務提 ...
  • 問題描述: 利用pyinstaller對python代碼打包後,dist文件夾中會生成一個xxx.exe可執行文件。打包成功,但運行exe時一閃而過(閃退)。捕捉不對到底是打包錯誤呢,還是其他異常?那麼如何解決? PS:以上現象在windows系統中會出現,在Linux和mac系統中不會出現。 解決 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...