题目:
一个整数可以由连续的自然数之和来表示,给定一个整数,计算该整数有几种连续自然数之和的表达式,并打印出每一种表达式。
输入描述
一个目标整数t 1<= t <=1000
输出描述
1.该整数的所有表达式和表达式的个数
如果有多种表达式,自然数个数最少的表达式优先输出
2.每个表达式中按自然数递增输出
具体的格式参见样例
在每个测试数据结束时,输出一行"Result:X"
其中X是最终的表达式个数
输入
9
输出
9=9
9=4+5
9=2+3+4
Result:3
说明 整数9有三种表达方法:
示例二
输入
10
输出
10=10
10=1+2+3+4
Result:2
代码1:
// 等差数列概念:公差d ; 通项公式:an = a1 + (n-1)d 。设首项为x,由题意得:d=1
// 前n项和公式为:sum = n(a1+an)/2 ;将an代入得到公式为:sum = n(2x+n-1)/2
//首项a1由公式推导为:x = n(sum - n(n-1)/2)/n 因此x = (2*sum-n*(n-1))/2*n
// 由于不知道n具体为几项,则通过循环获取,其中若要n最大时,可考虑首项为1
// 即可得到sum >= (1&#