算法--每日一练

1.数字A除本身以外的因数之和为数字BB除本身之外的因数之和为A,这样的数对称为相亲数,例如:220的真因数之和为1+2+4+5+10+11+20+22+44+55+110=284284的真因数之和为 1+2+4+71+142=220,请找出210000之间所有的相亲数。

php 复制代码
function index($m,$n){
$array = [];
define("N",$n);
for ($i = $m; $i < N; $i++){
for ($j = 1,$array[$i] = 0; $j < $i; $j++){
if ($i % $j == 0){
            $array[$i] += $j;
        }
    }
}
for ($i = $m; $i < N; $i++){
$j = $array[$i];
if ($j > N){
continue;
}
if ($i == $array[$j] && $j > $i){
echo $i." 与 ".$j." 为相亲数";
echo "\n";
}
}
}
index(2,10000);

2.兄弟四人的年龄成一等差数列,他们四人的年龄相加是26,相乘是880,求以他们的年龄为前4项的等差数列的前20项。

function lists ()
{
for ( a = 1 ; a <= 4 ; a ++ ){ for ( n = 1 ; n \<= 6 ; n ++ ){
if ( 4 * a + 6 \* n == 26 && a \* ( a + n ) \* ( a + n + n ) * ( a + n + n + n )
== 880 ){
for ( i = 1 ; i <= 20 ; i ++ ){ an = a + ( i - 1 ) * n ; echo an . " " ;
}
}
}
}
}
lists ();

*3.*水仙花数是指一个三位数,其各位数字立方和等于该数本身。例如:153 = 1³ + 5³ + 3³,所以 153是一个水仙花数;试找出所有三位数中的所有水仙花数。

function ShuiXian ( n , m )
{
for ( i = n ; i \<= m ; i ++ ){ arr = str_split ( i ); if ( i == (( arr \[ 0 \] \* arr [ 0 ] * arr \[ 0 \]) + ( arr [ 1 ] * arr \[ 1 \] \* arr [ 1 ]) + ( arr \[ 2 \] \* arr [ 2 ] * arr \[ 2 \]))){ echo i . "\n" ;
}
}
}
ShuiXian ( 100 , 999 );

*4.*用递归方法计算一个数的阶乘。

function fn2 ( n ) { if ( n == 0 || n == 1 ){ return 1 ; } fn = fn2 ( n - 1 ) \* n ;
return $fn ;
}
echo fn2 ( 4 );

5. 堆排序是利用堆积树的数据结构所设计的一种排序算法,可以根据数组索引快速定位到指定的数据元素。用堆排序的方式将数组*[49, 38,**65, 97, 76, 13, 27]*按照从小到大的方式排序。

function orderBy ( array array ) { length = count ( array ); for ( i = length / 2 - 1 ; i >= 0 ; i -- ){ array = adJustHeap ( array , i , length ); } for ( j = length - 1 ; j > 0 ; j -- ){ array = Swap ( array , 0 , j );
array = adJustHeap ( array , 0 , j ); } var_dump ( array );
}
function adJustHeap ( array array , i , length ) { temp = array \[ i ];
for ( k = i * 2 + 1 ; k \< length ; k = k * 2 + 1 ){
if ( k + 1 \< length && array \[ k ] < array \[ k + 1 ]){
k ++ ; } if ( array [ k \] \> temp ){
array \[ i ] = array \[ k ];
i = k ;
} else {
break ;
}
}
array \[ i ] = temp ; return array ;
}
function Swap ( array array , a , b ) { temp = array \[ a ];
array \[ a ] = array \[ b ];
array \[ b ] = temp ; return array ;
}
orderBy ([ 49 , 38 , 65 , 97 , 76 , 13 , 27 ]);

相关推荐
乐迪信息17 小时前
乐迪信息:煤矿堆煤隐患难排查?AI摄像机实时监控与预警
大数据·人工智能·算法·安全·视觉检测
一语雨在生无可恋敲代码~17 小时前
leetcode724 寻找数组的中心下标
数据结构·算法
科研小白_17 小时前
2025年优化算法:多策略改进蛇优化算法( Improved Snake Optimizer,ISO)
算法
88号技师17 小时前
【2025年10月一区SCI】改进策略:Trend-Aware Mechanism 趋势感知机制(TAM)-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
晨非辰17 小时前
《超越单链表的局限:双链表“哨兵位”设计模式,如何让边界处理代码既优雅又健壮?》
c语言·开发语言·数据结构·c++·算法·面试
胖咕噜的稞达鸭17 小时前
算法入门:专题攻克一---双指针4(三数之和,四数之和)强推好题,极其锻炼算法思维
开发语言·c++·算法
weixin_3077791318 小时前
C#实现MySQL→Clickhouse建表语句转换工具
开发语言·数据库·算法·c#·自动化
zc.ovo18 小时前
Kruskal重构树
数据结构·c++·算法·重构·图论
未来之窗软件服务1 天前
自己写算法(九)网页数字动画函数——东方仙盟化神期
前端·javascript·算法·仙盟创梦ide·东方仙盟·东方仙盟算法
豐儀麟阁贵1 天前
基本数据类型
java·算法