天天看点

算法练习:水仙花数、完全数、相亲数

输出所有水仙花数

一个三位数,每位的立方之和为其数本身

1

算法练习:水仙花数、完全数、相亲数

 for (int i = 100; i <= 999; i++)

2

算法练习:水仙花数、完全数、相亲数

 {

3

算法练习:水仙花数、完全数、相亲数

4

算法练习:水仙花数、完全数、相亲数

 if (Math.Pow(i / 100, 3) +

5

算法练习:水仙花数、完全数、相亲数

 Math.Pow((i / 10) - (i / 100) * 10, 3) +

6

算法练习:水仙花数、完全数、相亲数

 Math.Pow(i - i / 10 * 10, 3) == i)

7

算法练习:水仙花数、完全数、相亲数

8

算法练习:水仙花数、完全数、相亲数

 System.Console.WriteLine(

9

算法练习:水仙花数、完全数、相亲数

 "{0}:[{1}|{2}|{3}]", i, i / 100, (i / 10) - (i / 100) * 10, i - i / 10 * 10);

10

算法练习:水仙花数、完全数、相亲数

 }

11

算法练习:水仙花数、完全数、相亲数

输出10000以内的完全数

又称完美数,它是指真因子之和等于自身的自然数

算法练习:水仙花数、完全数、相亲数

 for (int i = 1; i <= 10000; i++)

算法练习:水仙花数、完全数、相亲数
算法练习:水仙花数、完全数、相亲数

 int k = 0;

算法练习:水仙花数、完全数、相亲数

 for (int j = 1; j <= i - 1; j++)

算法练习:水仙花数、完全数、相亲数
算法练习:水仙花数、完全数、相亲数

 if ((i % j) == 0)

算法练习:水仙花数、完全数、相亲数
算法练习:水仙花数、完全数、相亲数

 k += j;

算法练习:水仙花数、完全数、相亲数
算法练习:水仙花数、完全数、相亲数
算法练习:水仙花数、完全数、相亲数

 if (k == i)

12

算法练习:水仙花数、完全数、相亲数

13

算法练习:水仙花数、完全数、相亲数

 System.Console.WriteLine(i);

14

算法练习:水仙花数、完全数、相亲数

15

算法练习:水仙花数、完全数、相亲数

输出10000以内的相亲数

两个正整数,X的真因子之和等于Y的真因子之和

算法练习:水仙花数、完全数、相亲数
算法练习:水仙花数、完全数、相亲数
算法练习:水仙花数、完全数、相亲数

 int x = i;//X为初值

算法练习:水仙花数、完全数、相亲数

 int y = 0;

算法练习:水仙花数、完全数、相亲数

 for (int j = 1; j <= x - 1; j++)//计算X的真因子

算法练习:水仙花数、完全数、相亲数
算法练习:水仙花数、完全数、相亲数

 if ((x % j) == 0)

算法练习:水仙花数、完全数、相亲数

 { y += j; }

算法练习:水仙花数、完全数、相亲数

 }//Y=X的真因子之合

算法练习:水仙花数、完全数、相亲数

 if (y == x)//完美数

算法练习:水仙花数、完全数、相亲数

 { continue; }

算法练习:水仙花数、完全数、相亲数

 x = 0;

算法练习:水仙花数、完全数、相亲数

 for (int j = 1; j <= y - 1; j++)//计算Y的真因子

算法练习:水仙花数、完全数、相亲数
算法练习:水仙花数、完全数、相亲数

 if ((y % j) == 0)

16

算法练习:水仙花数、完全数、相亲数

 { x += j; }

17

算法练习:水仙花数、完全数、相亲数

 }//X=Y的真因子之合

18

算法练习:水仙花数、完全数、相亲数

 if (x == i)

19

算法练习:水仙花数、完全数、相亲数

20

算法练习:水仙花数、完全数、相亲数

 System.Console.WriteLine("{0}--{1}", x, y);

21

算法练习:水仙花数、完全数、相亲数

22

算法练习:水仙花数、完全数、相亲数

本文转自shyleoking 51CTO博客,原文链接:http://blog.51cto.com/shyleoking/806897

继续阅读