C++初學(xué)者之根據(jù)輸入的任何一個正整數(shù),輸出可能被表示的連續(xù)正整數(shù)
題目描述:一個正整數(shù)有可能可以被表示為 n(>=2) 個連續(xù)正整數(shù)之和,如:
15=1+2+3+4+5
15=4+5+6
15=7+8
請編寫程序,根據(jù)輸入的任何一個正整數(shù),找出符合這種要求的所有連續(xù)正整數(shù)序列。
輸入數(shù)據(jù):一個正整數(shù),以命令行參數(shù)的形式提供給程序。
輸出數(shù)據(jù):在標(biāo)準(zhǔn)輸出上打印出符合題目描述的全部正整數(shù)序列,每行一個序列,每個序列都從該序列的最小正整數(shù)開始、以從小到大的順序打印。如果結(jié)果有多個序列,按各序列的最小正整數(shù)的大小從小到大打印各序列。此外,序列不允許重復(fù),序列內(nèi)的整數(shù)用一個空格分隔。如果沒有符合要求的序列,輸出 “NONE” 。
例如,對于 15 ,其輸出結(jié)果是:
1 2 3 4 5
4 5 6
7 8
對于 16 ,其輸出結(jié)果是:
NONE
這是一道2005年百度之星程序設(shè)計大賽試題初賽題目。思路如下:
1、滿足要求的數(shù)是連續(xù)的,所以只要選定起始值累加求和即可;
2、要確保遍歷所有可能的起始值并且讓循環(huán)的次數(shù)盡量少。分析一下可以知道,一個數(shù)最少由兩個數(shù)求和構(gòu)成,又因為這兩個數(shù)是連續(xù)的。所以最大的起始值不會大于該數(shù)的二分之一。
代碼如下,VC6.0驗證OK。請拍磚,^_^
#include <iostream>
#include <vector>
using namespace std;
// 根據(jù)輸入的任何一個正整數(shù),輸出可能被表示的連續(xù)正整數(shù)
void Numbers(int number)
{
if (number <= )
{
return;
}
vector<int> save;
bool exist = false;
// 遍歷可能的起始值
for (int possible = ; possible < number / + ; possible++)
{
int start = possible;
int i = start;
int sum = ;
while (sum <= number) // 保存可以表示的連續(xù)正整數(shù)并輸出
{
sum += start;
if (sum == number)
{
exist = true;
for (; i < start + ; i++)
{
save.push_back(i);
}
for (i = ; i < save.size(); i++)
{
cout << save[i] << " ";
}
save.clear(); // 清空、準(zhǔn)備保存下一可能的序列
cout << endl;
}
start++;
}
}
if (false == exist)
{
cout << "NONE" << endl;
}
}
int main(int argc, char **argv)
{
const int number = ;
Numbers(number);
Numbers();
return ;
}
以上所述是小編給大家介紹的C++初學(xué)者之根據(jù)輸入的任何一個正整數(shù),輸出可能被表示的連續(xù)正整數(shù),希望對大家有所幫助!
- js判斷輸入是否為正整數(shù)、浮點(diǎn)數(shù)等數(shù)字的函數(shù)代碼
- 正則文本框只能輸入正整數(shù)
- JavaScript正則表達(dá)式校驗非零的正整數(shù)實例
- jquery 正整數(shù)數(shù)字校驗正則表達(dá)式
- JS只能輸入正整數(shù)的簡單實例
- 一種求正整數(shù)冪的高效算法詳解
- 只能輸入小于最大數(shù)且是正整數(shù)的腳本
- 使用JavaScript判斷用戶輸入的是否為正整數(shù)(兩種方法)
- JavaScript正則表達(dá)式校驗非正整數(shù)實例
- C++求四個正整數(shù)最大公約數(shù)的方法
- JQuery判斷正整數(shù)整理小結(jié)(jQuery 文本框中只能輸入正整數(shù))
相關(guān)文章
C++ Qt開發(fā)之ComboBox下拉組合框組件用法詳解
Qt 是一個跨平臺C++圖形界面開發(fā)庫,利用Qt可以快速開發(fā)跨平臺窗體應(yīng)用程序,在Qt中,ComboBox(組合框)是一種常用的用戶界面控件,它提供了一個下拉列表,允許用戶從預(yù)定義的選項中選擇一個,本文給大家介紹QComboBox類的一些常用方法,需要的朋友可以參考下2023-12-12
C++圖形界面開發(fā)Qt教程:嵌套圓環(huán)示例
這篇文章主要介紹了C++實現(xiàn)圖形界面開發(fā)Qt教程,涉及坐標(biāo)函數(shù)的應(yīng)用及圖形界面程序設(shè)計,需要的朋友可以參考下,希望能給你帶來幫助2021-08-08
C++數(shù)據(jù)模型應(yīng)用在QML委托代理機(jī)制中
這篇文章主要介紹了在QML委托代理機(jī)制中使用C++數(shù)據(jù)模型,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
C++11/14 線程調(diào)用類對象和線程傳參的方法
這篇文章主要介紹了C++11/14 線程調(diào)用類對象和線程傳參的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01

