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

相关文章

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

Java中注解与元数据示例详解

《Java中注解与元数据示例详解》Java注解和元数据是编程中重要的概念,用于描述程序元素的属性和用途,:本文主要介绍Java中注解与元数据的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参... 目录一、引言二、元数据的概念2.1 定义2.2 作用三、Java 注解的基础3.1 注解的定义3.2 内

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

使用Python实现操作mongodb详解

《使用Python实现操作mongodb详解》这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、示例二、常用指令三、遇到的问题一、示例from pymongo import MongoClientf

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

SQL注入漏洞扫描之sqlmap详解

《SQL注入漏洞扫描之sqlmap详解》SQLMap是一款自动执行SQL注入的审计工具,支持多种SQL注入技术,包括布尔型盲注、时间型盲注、报错型注入、联合查询注入和堆叠查询注入... 目录what支持类型how---less-1为例1.检测网站是否存在sql注入漏洞的注入点2.列举可用数据库3.列举数据库

Linux之软件包管理器yum详解

《Linux之软件包管理器yum详解》文章介绍了现代类Unix操作系统中软件包管理和包存储库的工作原理,以及如何使用包管理器如yum来安装、更新和卸载软件,文章还介绍了如何配置yum源,更新系统软件包... 目录软件包yumyum语法yum常用命令yum源配置文件介绍更新yum源查看已经安装软件的方法总结软