示例:假设您的用户输入是 6。那么总和为 6 的序列数是 11(包括 6 本身)。我遇到的问题是,当用户输入 1 或 6 时它可以工作,但如果不是,它就太远了,我不知道为什么。
如果需要,我可以提供有关该主题的更多信息。
#include <iostream>
using namespace std;
int sum(double number, int min, int & counter)
{
int temp=0, n;
n=number+temp;
if (number>=(n/2.0)+.5 && (number!=1))
{
number --;
temp ++;
while (number>=(n/2.0))
{
number --;
temp ++;
counter ++;
}
}
else if (number==1)
{
counter ++;
return 0;
}
sum(n-1, 1,counter);
return 0;
}
int main()
{
int counter=1;
double number;
cout << "-------------------------------------------------------\n"
<< "Please enter the number: ";
cin >> number ;
cout << "\n";
if (number!=1)
{
sum(number, 1, counter);
}
cout << "The total number of combinations that result in a sum of "
<< number << " is: " << counter
<< "\n-------------------------------------------------------\n";
return 0;
}