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

相关文章

Python装饰器之类装饰器详解

《Python装饰器之类装饰器详解》本文将详细介绍Python中类装饰器的概念、使用方法以及应用场景,并通过一个综合详细的例子展示如何使用类装饰器,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录1. 引言2. 装饰器的基本概念2.1. 函数装饰器复习2.2 类装饰器的定义和使用3. 类装饰

MySQL 中的 JSON 查询案例详解

《MySQL中的JSON查询案例详解》:本文主要介绍MySQL的JSON查询的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 的 jsON 路径格式基本结构路径组件详解特殊语法元素实际示例简单路径复杂路径简写操作符注意MySQL 的 J

C语言中位操作的实际应用举例

《C语言中位操作的实际应用举例》:本文主要介绍C语言中位操作的实际应用,总结了位操作的使用场景,并指出了需要注意的问题,如可读性、平台依赖性和溢出风险,文中通过代码介绍的非常详细,需要的朋友可以参... 目录1. 嵌入式系统与硬件寄存器操作2. 网络协议解析3. 图像处理与颜色编码4. 高效处理布尔标志集合

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

Python ZIP文件操作技巧详解

《PythonZIP文件操作技巧详解》在数据处理和系统开发中,ZIP文件操作是开发者必须掌握的核心技能,Python标准库提供的zipfile模块以简洁的API和跨平台特性,成为处理ZIP文件的首选... 目录一、ZIP文件操作基础三板斧1.1 创建压缩包1.2 解压操作1.3 文件遍历与信息获取二、进阶技

一文详解Java异常处理你都了解哪些知识

《一文详解Java异常处理你都了解哪些知识》:本文主要介绍Java异常处理的相关资料,包括异常的分类、捕获和处理异常的语法、常见的异常类型以及自定义异常的实现,文中通过代码介绍的非常详细,需要的朋... 目录前言一、什么是异常二、异常的分类2.1 受检异常2.2 非受检异常三、异常处理的语法3.1 try-

Java中的@SneakyThrows注解用法详解

《Java中的@SneakyThrows注解用法详解》:本文主要介绍Java中的@SneakyThrows注解用法的相关资料,Lombok的@SneakyThrows注解简化了Java方法中的异常... 目录前言一、@SneakyThrows 简介1.1 什么是 Lombok?二、@SneakyThrows

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

Redis Pipeline(管道) 详解

《RedisPipeline(管道)详解》Pipeline管道是Redis提供的一种批量执行命令的机制,通过将多个命令一次性发送到服务器并统一接收响应,减少网络往返次数(RTT),显著提升执行效率... 目录Redis Pipeline 详解1. Pipeline 的核心概念2. 工作原理与性能提升3. 核

Python正则表达式语法及re模块中的常用函数详解

《Python正则表达式语法及re模块中的常用函数详解》这篇文章主要给大家介绍了关于Python正则表达式语法及re模块中常用函数的相关资料,正则表达式是一种强大的字符串处理工具,可以用于匹配、切分、... 目录概念、作用和步骤语法re模块中的常用函数总结 概念、作用和步骤概念: 本身也是一个字符串,其中