水仙花数&素数&质因数分解的C语言实现

简介: 最近,我翻了一下之前的C语言教材,看了三个有意思的小程序,包括:寻找“水仙花数”、判断某数是否为素数、对一个数进行质因数分解。我想把这三个东西放到一个程序中,便写下了此文。

最近,我翻了一下之前的C语言教材,看了三个有意思的小程序,包括:寻找“水仙花数”、判断某数是否为素数、对一个数进行质因数分解。我想把这三个东西放到一个程序中,便写下了此文。

 

算法步骤

1. 寻找“水仙花数”。

“水仙花数”是指一个三位数,其各位数字的立方和等于该数本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。

 

2. 判断某数是否为素数。

素数是指只能被1和它本身整除的数,判断一个数是否为素数的方法:用这个数分别去除以2到这个数的平方根,如果能被整除,则表明此数不是素数,反之是素数。

 

3. 对一个数进行质因数分解。

对一个数n进行质因数分解,应先找到一个质数k(从最小的2开始),然后按下述步骤进行:

(1) 如果这个质数恰好等于n,则说明分解质因数的过程已经结束。 

(2) 如果n不等于k,但n能被k整除,则应用n除以k的商作为新的正整数n,重复执行第一步。

(3) 如果n不能被k整除,则用k+1作为k的新值,重复执行第一步。

 

本程序流程

本程序分三步走:第一步,寻找“水仙花数”;第二步,判断找到的“水仙花数”是否是素数;第三步,如果不是素数,则对这个数进行质因数分解。

 

C程序代码

/**********************************************************************
* 版权所有 (C)2015, Zhou Zhaoxiong。
*
* 文件名称:AlgorithmStudy.c
* 文件标识:无
* 内容摘要:算法学习: 水仙花数+素数+质因数分解
* 其它说明:无
* 当前版本:V1.0
* 作    者:Zhou Zhaoxiong
* 完成日期:20150327
*
**********************************************************************/
#include 
#include 
 
 
typedef signed   int    INT32;
typedef unsigned char   UINT8;
typedef unsigned int    UINT32;
 
 
/**********************************************************************
* 功能描述:主函数
* 输入参数:无
* 输出参数:无
* 返 回 值:无
* 其它说明:无
* 修改日期      版本号       修改人          修改内容
* -------------------------------------------------------------------
* 20150327       V1.0     Zhou Zhaoxiong       创建
***********************************************************************/
INT32 main()
{
       UINT32 iBaiWei         = 0;     // 三位数的百位数字
       UINT32 iShiWei         = 0;     // 三位数的十位数字
       UINT32 iGeWei          = 0;     // 三位数的个位数字
       UINT32 iJudgedNum      = 0;     // 三位数, 从101开始算起
       UINT8 iPrimeFlag       = 0;     // 一个数是否是素数的标识
       UINT32 iLoopFlag       = 0;     // 用于循环中
       UINT32 iDaffodilNumber = 0;     // 水仙花数
       UINT32 iTempNum        = 0;     // 作为过渡数
 
       for (iJudgedNum = 101; iJudgedNum 

编译命令

本程序在Linux下进行编译,编译命令为:gcc -g -o AlgorithmStudyAlgorithmStudy.c –lm。

注意,不要忽略了“–lm”,否则编译时会报错,提示找不到“sqrt”。

 

程序运行结果

编译成功之后,执行“AlgorithmStudy”命令,结果如下:

153是一个水仙花数.

153不是素数.

153=3*3*17

------

370是一个水仙花数.

370不是素数.

370=2*5*37

------

371是一个水仙花数.

371不是素数.

371=7*53

------

407是一个水仙花数.

407不是素数.

407=11*37

------

 

 

---------------------------------------------------

本人微信公众号:zhouzxi,请扫描以下二维码:

 

目录
相关文章
|
23天前
|
C语言
C语言之完数、素数、回文数合集
C语言之完数、素数、回文数合集
|
1月前
|
C语言
【01】判断素数/质数(C语言)
【01】判断素数/质数(C语言)
|
3月前
|
C语言
C语言Oj题判断素数几种方式详解
输入一个数判断它是不是素数,并且不是的情况把它打印出来不是素数。
|
4月前
|
C语言
c语言编程练习题:7-33 统计素数并求和
c语言编程练习题:7-33 统计素数并求和
22 0
|
1月前
|
C语言
【C语言】输入一个数n,输出从n到n+100的范围内所有的素数,并统计素数的个数
【C语言】输入一个数n,输出从n到n+100的范围内所有的素数,并统计素数的个数
24 0
|
1月前
|
算法 C语言
C语言判断素数
C语言判断素数
15 0
|
3月前
|
C语言
【C 语言经典100例】C 练习实例36 - 求100之内的素数
【C 语言经典100例】C 练习实例36 - 求100之内的素数
18 0
|
3月前
|
C语言
【C 语言经典100例】C 练习实例33 - 质数(素数)判断
【C 语言经典100例】C 练习实例33 - 质数(素数)判断
18 0
|
5月前
|
C语言
C语言素数判断以及打印素数表
C语言素数判断以及打印素数表
106 0
|
5月前
|
算法 搜索推荐 程序员
C语言第十三练——输入一个正整数,判断这个数是否是素数
C语言第十三练——输入一个正整数,判断这个数是否是素数
88 0