Perfect Numbers

1. Perfect Numbers
If number can be written as:a^m+b^n, where a,b>=1,
m,n>=2, we call it perfect number.

e.g., 1 is not a perfect number as there is no way to write 1
in this form.
2=1^2+1^2.Thus 2 is perfect number.
3 is not either.
4 is not.
5=1^2+2^2.thus5 is perfect number.

Find out how many numbers between 1-N are perfect
numbers. Example:
If N=1, return 0.
If N=2, return 1(2 is a perfect number)
If N=3, return(only 2 is a perfect number).
If N=5, return 2 (both 2 and 5 are perfect numbers).

N can be as large as 1,000,000.

解题思路:

a^m 可以看做一个矩阵 a行m列的矩阵

1^2 1^3 ……

2^2 2^3 ……

……

……

同理b^n,甚至和a^m可以试做同一个矩阵

矩阵上任意两个数相加,即为完美数字

最小数字a=1,m=2,per num=1+b^n

故求矩阵最大行列

行2^x-1<N-1 <= 2^x

列y-1^2<N-1<=y^2

得矩阵x * y

遍历矩阵取所有小于N的数,得数组A

循环A两次,取两数相加小于等于N的

源码下载

https://download.csdn.net/download/jine1987/14954663

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值