C语言求取完数-程序详解(1-1000以内,谭浩强C语言5-9习题)

2024-03-16 09:30

本文主要是介绍C语言求取完数-程序详解(1-1000以内,谭浩强C语言5-9习题),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录:

1.1:程序实现的要求:

1.2、 程序主体思路:

1.3、代码详解:

前言:该文章讲解一个程序,功能是对完数的判断和对完数因子的输出,对应于《C语言程序设计》谭浩强第四版第五章第9题。因博主能力水平有限,若程序或者讲解有误,请各位多指正建议。

1.1:程序实现的要求:

一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如,6的因子为1,2,3,而6=1+2+3,因此6是“完数”。编程序找出1000之内的所有完数,并按下面格式输出其因子:6 its factors are 1,2,3

1.2、 程序主体思路:

 求取完数可以尝试用一个函数实现,该函数可以用一个返回值来表示它是否是完数(返回值1表示该数是完数,返回值为0则不是完数)。求取因子,可以往该函数里传入一个一维数组,该数组可以存储一个数的因子,每次传入新的数时,对该数组进行初始化。此外可在主函数之中对显示该数组的元素,即可显示完数和完数的因子。

1.3、代码详解:

求取完数的函数int GetPerNum(int n,int arr[100]):函数的返回值类型是int型,传入的参数有两个,一个传入的数,类型是int型,一个是数组,用于存储数的因子,数组元素的类型是int型。

int GetPerNum(int n,int arr[100])//求取完数的函数,数组存储完数的因子
{int i = 0;int sum = 0;//因子的和int j = 0;for (i = 1; i <= n/2; i++)//一个数的最大因子(不包括本身)到n/2;也可设置到n-1;{if (n % i == 0)//如果是i是n的因子{sum = sum + i;//将因子相加arr[j] = i;//将相应的因子存储到数组中j++;}}if (sum == n)//数的因子和等于该数{return 1;//是完数返回1}return 0;//不是完数返回0
}

主函数:主函数定义了一个一维数组arr,该数组里有100 个元素,保证能够存储一个数的所有因子。当然,也可以将数组的元素减小一些,如20个;主函数还定义了一个i,i是为了产生1-1000的数。还定义了一个j,是为了遍历arr数组。

在主函数中,通过一个for循环来产生1-1000的数,首先对arr数组进行初始化,数组里的所有元素初始化为0;之后通过调用GetPerNum函数,判断一个数是否为完数;如果为完数,打印该数,并且遍历该数组,打印所有不为0的元素,遇到0元素时,换行,并且跳过内部的一个for循环(主函数里有两个for循环,跳出的是for (j = 0; j <= 100; j++))。

int main()
{int i = 0;int j = 0;//printf("完数是以下几个数\n");//可以将该语句屏蔽,输出窗口就不显示“完数是以下几个数”for (i = 1; i <= 1000; i++)//获取1-1000的数{int arr[100] = { 0 };//每次都会初始化一下数组,数组里设置100个元素,是为了保证数组容量足够;也可设置20个元素;if (GetPerNum(i, arr) == 1)//如果该数是完数,是完数的话,GetPerNum函数返回值为1{printf("%d ", i);//打印该完数printf("its factors are");for (j = 0; j <= 100; j++)//遍历arr数组的元素{if (arr[j] != 0 )//元素不为0的元素打印{printf("%d", arr[j]);if (arr[j + 1] != 0)//最后一个因子后面不打印“,”{printf(",");}}else//元素为0时,从此元素开始,后面的元素都为0,都不需要打印了{printf("\n");//换行break;//此时跳过内部循环}}}}return 0;
}

输出显示:

1.3、程序代码:

#include <stdio.h>
int GetPerNum(int n,int arr[100])//求取完数的函数,数组存储完数的因子
{int i = 0;int sum = 0;//因子的和int j = 0;for (i = 1; i <= n/2; i++)//一个数的最大因子(不包括本身)到n/2;也可设置到n-1;{if (n % i == 0)//如果是i是n的因子{sum = sum + i;//将因子相加arr[j] = i;//将相应的因子存储到数组中j++;}}if (sum == n)//数的因子和等于该数{return 1;//是完数返回1}return 0;//不是完数返回0
}int main()
{int i = 0;int j = 0;//printf("完数是以下几个数\n");//可以将该语句屏蔽,输出窗口就不显示“完数是以下几个数”for (i = 1; i <= 1000; i++)//获取1-1000的数{int arr[100] = { 0 };//每次都会初始化一下数组,数组里设置100个元素,是为了保证数组容量足够;也可设置20个元素;if (GetPerNum(i, arr) == 1)//如果该数是完数,是完数的话,GetPerNum函数返回值为1{printf("%d ", i);//打印该完数printf("its factors are");for (j = 0; j <= 100; j++)//遍历arr数组的元素{if (arr[j] != 0 )//元素不为0的元素打印{printf("%d", arr[j]);if (arr[j + 1] != 0)//最后一个因子后面不打印“,”{printf(",");}}else//元素为0时,从此元素开始,后面的元素都为0,都不需要打印了{printf("\n");//换行break;//此时跳过内部循环}}}}return 0;
}

这篇关于C语言求取完数-程序详解(1-1000以内,谭浩强C语言5-9习题)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/815041

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

MyBatis常用XML语法详解

《MyBatis常用XML语法详解》文章介绍了MyBatis常用XML语法,包括结果映射、查询语句、插入语句、更新语句、删除语句、动态SQL标签以及ehcache.xml文件的使用,感兴趣的朋友跟随小... 目录1、定义结果映射2、查询语句3、插入语句4、更新语句5、删除语句6、动态 SQL 标签7、ehc

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Java中的.close()举例详解

《Java中的.close()举例详解》.close()方法只适用于通过window.open()打开的弹出窗口,对于浏览器的主窗口,如果没有得到用户允许是不能关闭的,:本文主要介绍Java中的.... 目录当你遇到以下三种情况时,一定要记得使用 .close():用法作用举例如何判断代码中的 input