C++初學者---根據輸入的任何一個正整數,輸出可能被表示的連續正整數

来源:http://www.cnblogs.com/shouce/archive/2016/03/07/5249311.html
-Advertisement-
Play Games

題目描述:一個正整數有可能可以被表示為 n(>=2) 個連續正整數之和,如: 15=1+2+3+4+5 15=4+5+6 15=7+8 請編寫程式,根據輸入的任何一個正整數,找出符合這種要求的所有連續正整數序列。 輸入數據:一個正整數,以命令行參數的形式提供給程式。 輸出數據:在標準輸出上列印出符合


題目描述:一個正整數有可能可以被表示為 n(>=2) 個連續正整數之和,如:

15=1+2+3+4+5 
15=4+5+6 
15=7+8

請編寫程式,根據輸入的任何一個正整數,找出符合這種要求的所有連續正整數序列。

輸入數據:一個正整數,以命令行參數的形式提供給程式。

輸出數據:在標準輸出上列印出符合題目描述的全部正整數序列,每行一個序列,每個序列都從該序列的最小正整數開始、以從小到大的順序列印。如果結果有多個序列,按各序列的最小正整數的大小從小到大列印各序列。此外,序列不允許重覆,序列內的整數用一個空格分隔。如果沒有符合要求的序列,輸出 “NONE” 。

例如,對於 15 ,其輸出結果是: 
1 2 3 4 5 
4 5 6 
7 8 
對於 16 ,其輸出結果是: 
NONE

這是一道2005年百度之星程式設計大賽試題初賽題目。思路如下:

1、滿足要求的數是連續的,所以只要選定起始值累加求和即可;

2、要確保遍歷所有可能的起始值並且讓迴圈的次數儘量少。分析一下可以知道,一個數最少由兩個數求和構成,又因為這兩個數是連續的。所以最大的起始值不會大於該數的二分之一。

代碼如下,VC6.0驗證OK。請拍磚,^_^

複製代碼
 1 #include <iostream>
 2 #include <vector>
 3 
 4 using namespace std;
 5 
 6 // 根據輸入的任何一個正整數,輸出可能被表示的連續正整數
 7 void Numbers(int number)
 8 {
 9     if (number <= 0)
10     {
11         return;
12     }
13 
14     vector<int> save;
15     bool exist = false;
16     // 遍歷可能的起始值
17     for (int possible = 1; possible < number / 2 + 1; possible++)
18     {
19         int start = possible;
20         int i = start;
21         int sum = 0;
22         while (sum <= number) // 保存可以表示的連續正整數並輸出
23         {
24             sum += start;
25             if (sum == number)
26             {
27                 exist = true;
28                 for (; i < start + 1; i++)
29                 {
30                     save.push_back(i);
31                 }
32                 
33                 for (i = 0; i < save.size(); i++)
34                 {
35                     cout << save[i] << " ";
36                 }
37                 save.clear(); // 清空、準備保存下一可能的序列
38                 cout << endl;
39             }
40             start++;
41         }
42     }
43 
44     if (false == exist)
45     {
46         cout << "NONE" << endl;
47     }
48 }
49 
50 int main(int argc, char **argv)
51 {
52     const int number = 21;
53     Numbers(number);
54     Numbers(16);
55 
56     return 0;
57 }
複製代碼

 


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

-Advertisement-
Play Games
更多相關文章
  • 最近公司要做一個項目,需要和現有的其他項目對接,由於不知道他們的資料庫,只有XSD文件。所以,我們在修改相應的程式時,就需要根據他們提供的XSD文件,來寫我們的VO實體類,由於我寫過根據Oracle資料庫生成VO實體類,因此這次的這個活也就很自然的落在了我的頭上。 一、XSD 首先什麼是XSD,我就
  • 摘要: 2016年,Wijmo將專註於:根據客戶的需求打磨控制項,包括性能、功能和修複;增加一些主要的新控制項,比如OLAP、報表、MultiRow;支持Angular 2, Aurelia, EmberJS框架
  • 開啟新的讀書之旅,這次讀的書為《.Net之美:.Net關鍵技術深入解析》。 我是選擇性閱讀的,把一些自己覺得容易忘記的,或者比較重要的知識點記錄下來,以便以後能方便呢查閱。 尊重書本原作者,如果大家能有個可能的話,去看看這本書,作者寫得挺不錯的。例子和知識點各方面都寫挺不錯的。 本章的內容 什麼是委
  • 這篇文章的目的主要為了後續工作的使用,在這裡對S2深入.NET平臺和C#編程中貫穿案例《網路電視精靈》的部分實現代碼進行思路剖析。 一.項目框架的搭建: 這個界面需要的控制項MenuStrip、TreeView、TabControl、ListView、DataGridView。 思路分析: 1.創建對
  • 這兩天寫的代碼概率性的崩潰在 XMMatrixMultiply() 函數,XMMatrixMultiply() 本身是 inline 函數可以看到崩潰處的代碼: vX = _mm_mul_ps(vX,M2.r[0]); 經查,_mm_mul_ps 是 SSE2 指令要求記憶體地址 16 位元組對齊。猜想
  • .NET環境下基於RBAC的訪問控制 Access Control of Application Based on RBAC model in .NET Environment 摘 要:本文從目前信息系統的變化趨勢及其多資源的訪問問題出發,提出一種基於RBAC模型的訪問控制方案。該方案以.NET環境
  • 標準輻射場裝置控制系統軟體設計。
  • 做過後臺的,應該都知道,經常要用到iframe來處理導航,如果按一般的思路來做這個功能,還是挺簡單的 可是當我用smarty的時候,就發現了問題,比如,一個iframeset分成了:頭部top,左邊menu,右邊main, 正常情況,用smarty來處理的話,一般是這樣: 如果3個頁面僅僅只是靜態頁
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...