题目31


一个整数可以由连续的自然数之和来表示
给定一个整数
计算该整数有几种连续自然数之和的表达式
并打印出每一种表达式

输入描述
一个目标整数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

<?php
$n=fgets(STDIN);
solution($n);

function solution($t)
{
    echo $t.'='.$t.PHP_EOL;
    $arr=[];
    for($i=1;$i<$t;$i++){
        $sum=0;
        $str='';
        for ($j=$i;$j<$t;$j++){
            $sum+=$j;
            $str.=$j.'+';
            if($sum==$t){
                $arr[]=$t.'='.trim($str,'+');
                break;
            }
        }
    }
    uasort($arr, function ($a, $b) {
        return strLen($a) > strLen($b);//用>是从短到长
    });
    foreach ($arr as $item){
        echo $item.PHP_EOL;
    }
    echo 'Result:'.(count($arr)+1);
}

 

原创文章,作者:bd101bd101,如若转载,请注明出处:https://blog.ytso.com/275524.html

(0)
上一篇 2022年7月20日
下一篇 2022年7月20日

相关推荐

发表回复

登录后才能评论