C语言:打印0-100000中的自幂数(水仙花数是其中一种)

news2024/11/24 18:44:14

题目:

0~100000 之间的所有 自幂数输出

自幂数指一个n位数,其各位数字n次方之和恰好等于该数本身

如:153=1^3+5^3+3^3

153是一个自幂数

                    

 =========================================================================

                       

思路:

总体思路:

(一).

计算 i 的位数

                 

使用 for循环 产生 0~100000 的数变量i

            

使用一个变量 tmp 代替 i防止后续操作改变循环变量 i

int tmp = i;

           

开始计算 i 的位数

一个数 至少也是 一位数,所以 n 起始1

n = 1;

使用 while循环,如果 tmp/10 不为0,说明有位数位数加一n+1直到 tmp/10 == 0

                

(二).

求每一位的 n次方之和

                

因为上一步 tmp /= 10 改变了 tmp 的值,所以要再替换一次 i

tmp = i;

           

创建变量 sum 存放每位次方后的和

int sum = 0;

           

使用 while循环,如果 tmp 不等于 0继续取出当前位进行计算

sum += pow(tmp % 10, n);

pow()函数为求第一个参数的第二个参数次方,需要<math.h>头文件

%10 取出当前位后,当前位的n次方,再求和赋给sum

计算完当前位后,移至该数的下一位

tmp /= 10;

                  

(三).

判断 sum 是不是自幂数是则进行打印

                


                 

第一步:

计算 i 的位数

                 

(1).

使用 for循环 产生 0~100000 的数变量i

            

(2).

使用一个变量 tmp 代替 i防止后续操作改变循环变量 i

int tmp = i;

           

(3).

开始计算 i 的位数

一个数 至少也是 一位数,所以 n 起始1

n = 1;

使用 while循环,如果 tmp/10 不为0,说明有位数位数加一n+1直到 tmp/10 == 0

                     

实现代码:

#include <stdio.h>

int main()
{
	//使用for循环产生 0~100000 的数:
	int i = 0;
	for (i = 0; i <= 100000; i++)
	{
		//使用变量 tmp 代替 i,防止后续操作改变循环变量:
		int tmp = i; //代替 i

		//计算 i 的位数:
		int n = 1; //位数,因为一个数至少也是一位数,所以n起始为1

		//思路:i/10 --> 可以去掉一位 --> n+1 ,直到 i/10==0
		while (tmp /= 10) //直到tem/10==0,停止循环
		{
			n++;//统计位数
		}
		
	}

	return 0;
}

实现图片:

                 


                 

第二步:

求每一位的 n次方之和

                

(1).

因为上一步 tmp /= 10 改变了 tmp 的值,所以要再替换一次 i

tmp = i;

           

(2).

创建变量 sum 存放每位次方后的和

int sum = 0;

           

(3).

使用 while循环,如果 tmp 不等于 0继续取出当前位进行计算

sum += pow(tmp % 10, n);

pow()函数为求第一个参数的第二个参数次方,需要<math.h>头文件

%10 取出当前位后,当前位的n次方,再求和赋给sum

计算完当前位后,移至该数的下一位

tmp /= 10;

                     

实现代码:

#include <stdio.h>
#include <math.h>
int main()
{
	//使用for循环产生 0~100000 的数:
	int i = 0;
	for (i = 0; i <= 100000; i++)
	{
		//使用变量 tmp 代替 i,防止后续操作改变循环变量:
		int tmp = i; //代替 i

		//计算 i 的位数:
		int n = 1; //位数,因为一个数至少也是一位数,所以n起始为1

		//思路:i/10 --> 可以去掉一位 --> n+1 ,直到 i/10==0
		while (tmp /= 10) //直到tem/10==0,停止循环
		{
			n++;//统计位数
		}
		
		//因为上面改变了 tmp /= 10 ,改变了 tmp 的值,
		//所以要再替换一次 i :
		tmp = i;

		//创建变量 sum 存放该数每一位次方的和:
		int sum = 0;

		//只要 i 不等于0,就继续取出下一位:
		while (tmp)
		{
			//%10,取出一位后,求出该位的n次方,再求和
			sum += pow(tmp % 10, n);

			//计算下一位:
			tmp /= 10;
		}

	}

	return 0;
}

实现图片:

                 


                 

第三步:

判断 sum 是不是自幂数是则进行打印

                     

实现代码:

#include <stdio.h>
#include <math.h>
int main()
{
	//使用for循环产生 0~100000 的数:
	int i = 0;
	for (i = 0; i <= 100000; i++)
	{
		//使用变量 tmp 代替 i,防止后续操作改变循环变量:
		int tmp = i; //代替 i

		//计算 i 的位数:
		int n = 1; //位数,因为一个数至少也是一位数,所以n起始为1

		//思路:i/10 --> 可以去掉一位 --> n+1 ,直到 i/10==0
		while (tmp /= 10) //直到tem/10==0,停止循环
		{
			n++;//统计位数
		}
		
		//因为上面改变了 tmp /= 10 ,改变了 tmp 的值,
		//所以要再替换一次 i :
		tmp = i;

		//创建变量 sum 存放该数每一位次方的和:
		int sum = 0;

		//只要 i 不等于0,就继续取出下一位:
		while (tmp)
		{
			//%10,取出一位后,求出该位的n次方,再求和
			sum += pow(tmp % 10, n);

			//计算下一位:
			tmp /= 10;
		}

		//判断sum是不是自幂数
		if (sum == i)
		{
			printf("%d ", i);//是则进行打印
		}

	}

	return 0;
}

实现图片:

                    

最终代码和实现效果

最终代码:

#include <stdio.h>
#include <math.h>
int main()
{
	//使用for循环产生 0~100000 的数:
	int i = 0;
	for (i = 0; i <= 100000; i++)
	{
		//使用变量 tmp 代替 i,防止后续操作改变循环变量:
		int tmp = i; //代替 i

		//计算 i 的位数:
		int n = 1; //位数,因为一个数至少也是一位数,所以n起始为1

		//思路:i/10 --> 可以去掉一位 --> n+1 ,直到 i/10==0
		while (tmp /= 10) //直到tem/10==0,停止循环
		{
			n++;//统计位数
		}
		
		//因为上面改变了 tmp /= 10 ,改变了 tmp 的值,
		//所以要再替换一次 i :
		tmp = i;

		//创建变量 sum 存放该数每一位次方的和:
		int sum = 0;

		//只要 i 不等于0,就继续取出下一位:
		while (tmp)
		{
			//%10,取出一位后,求出该位的n次方,再求和
			sum += pow(tmp % 10, n);

			//计算下一位:
			tmp /= 10;
		}

		//判断sum是不是自幂数
		if (sum == i)
		{
			printf("%d ", i);//是则进行打印
		}

	}

	return 0;
}

实现效果:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/685140.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【数据网格架构】分布式数据网格作为集中式数据单体的解决方案

企业数据架构师不应构建大型集中式数据平台&#xff0c;而应创建分布式数据网格。 ThoughtWorks 的首席技术顾问 Zhamak Dehghani 在旧金山 QCon 的演讲和相关文章中表示&#xff0c;这种方法的改变需要范式转变。随着数据变得越来越普遍&#xff0c;传统的数据仓库和数据湖架构…

Linux基础+命令操作+mysql、tomcat、nginx、RabbitMQ、Redis,ElasticSearch

配置代理 一、永久设置 //编辑配置文件 vi /etc/profile //在该配置文件的最后添加代理配置 export http_proxyhttp://f1336515:password10.137.255.169:3128 //代理服务器ip地址和端口号 export https_proxyhttp://f1336515:password10.137.255.169:3128 //代理服务器ip…

【软考网络管理员】2023年软考网管初级常见知识考点(11)-TCP和UDP详解

涉及知识点 传输控制协议TCP是什么&#xff0c;三次握手的概念理解&#xff0c;用户数据报协议UDP是什么&#xff0c;软考网络管理员常考知识点&#xff0c;软考网络管理员网络安全&#xff0c;网络管理员考点汇总。 原创于&#xff1a;CSDN博主-《拄杖盲学轻声码》&#xff0…

AntV G6新版源码浅析

前言 AntV是蚂蚁金服全新一代数据可视化解决方案&#xff0c;其中G6主要用于解决图可视领域相关的前端可视化问题&#xff0c;其是一个简单、易用、完备的图可视化引擎。本文旨在通过简要分析G6 5.x版本源码来对图可视领域的一些底层引擎进行一个大致了解&#xff0c;同时也为…

【玩转Linux操作】详细讲解expr,read,echo,printf,test,[]等命令

&#x1f38a;专栏【玩转Linux操作】 &#x1f354;喜欢的诗句&#xff1a;更喜岷山千里雪 三军过后尽开颜。 &#x1f386;音乐分享【free loop】 大一同学小吉&#xff0c;欢迎并且感谢大家指出我的问题&#x1f970; 文章目录 &#x1f354;expr命令⭐表达式说明 &#x1f3…

JAVA:Springboot动态装配Druid多数据源

1、简介 最近打算搭建一个鉴权中心服务&#xff0c;采用springbootFastMybatis装配Druid&#xff0c;考虑后续拓展采用Druid多数据源配置&#xff0c;以一个数据源为主&#xff0c;多个动态数据源为辅的结构。除了数据库&#xff0c;后续会结合shiro安全框架来搭建。 2、引用…

【Leetcode60天带刷】day33回溯算法——1005.K次取反后最大化的数组和 134. 加油站 135. 分发糖果

​ 题目&#xff1a; 1005. K 次取反后最大化的数组和 给你一个整数数组 nums 和一个整数 k &#xff0c;按以下方法修改该数组&#xff1a; 选择某个下标 i 并将 nums[i] 替换为 -nums[i] 。 重复这个过程恰好 k 次。可以多次选择同一个下标 i 。 以这种方式修改数组后&am…

将视频转为幻灯片图像:利用OpenCV实现视频资料转换的指南

视频成为了传播知识和信息的重要媒介之一。然而&#xff0c;有时我们需要以静态的形式保存视频内容&#xff0c;例如将视频讲座转换为幻灯片或图像&#xff0c;以便于分享、存档或打印。幸运的是&#xff0c;OpenCV这一功能强大的计算机视觉库提供了各种技术和工具&#xff0c;…

机器学习之线性回归算法

目录 线性回归算法 求导法推导 梯度下降法推导 线性回归实现人脸识别 导入数据 构建标签矩阵 经典线性回归求导法实现 经典线性回归梯度下降法实现 岭回归实现 套索回归实现 局部加权线性回归实现 可视化 人脸识别 线性回归算法 求导法推导 梯度下降法推导 线性回…

chatgpt赋能python:Title:Python编程中的空格怎么用?详细教程!

Title: Python编程中的空格怎么用&#xff1f;详细教程&#xff01; Introduction: Python编程的空格使用一直是令人困惑的话题之一&#xff0c;但它却是Python语言中非常重要的一部分。空格在Python程序中用来表示代码块的开始和结束&#xff0c;因此不同的空格使用方式可能…

【夜深人静学数据结构与算法 | 第十篇】动态规划

目录 前言&#xff1a; 动态规划&#xff1a; 常见应用&#xff1a; 解题步骤&#xff1a; 动态规划的简化步骤&#xff1a; 案例&#xff1a; 509. 斐波那契数 - 力扣&#xff08;LeetCode&#xff09; 70. 爬楼梯 - 力扣&#xff08;LeetCode&#xff09; 62. 不同路…

【软考网络管理员】2023年软考网管初级常见知识考点(10)- 网际协议IP及IPV6,IPV4详解

涉及知识点 分类的IP地址&#xff0c;子网划分&#xff0c;CIDR和路由汇聚&#xff0c;IPV4数据报格式&#xff0c;IPV6协议&#xff0c;软考网络管理员常考知识点&#xff0c;软考网络管理员网络安全&#xff0c;网络管理员考点汇总。 原创于&#xff1a;CSDN博主-《拄杖盲学…

Java的理论知识部分

文章目录 前言 一、Java的发展 1.1、Java的出现 1.2、Java官方网址 1.3、Java的平台 1.4、Java各版本新加的内容 1.5、java特点 1.6、Java的三种运行机制 1.7、Java的编译与运行 1.8、补充内容——华为鲲鹏jdk以及鲲鹏计算 二、面向对象程序编程 2.1、对象与类 2.2、Ja…

第一次安装cocoapods经历

先是执行&#xff1a;sudo gem install cocoapods 报错&#xff1a; ERROR: Error installing cocoapods: The last version of activesupport (> 5.0, < 8) to support your Ruby & RubyGems was 6.1.7.3. Try installing it with gem install activesupport -v…

无需麻烦,快速下载MySQL JDBC驱动程序!

如何提升你的MySQL数据库操作速度呢&#xff1f; 不必再费时寻找&#xff0c;我讲为你带来最简便、快速的MySQL JDBC驱动程序下载方法&#xff01; 无需繁琐步骤&#xff0c;轻松获取所需&#xff0c;让你的数据库操作更加流畅&#xff0c;事半功倍&#xff01;立即点击下载即…

高速数据采集专家--青翼8通道125MSPS 16位AD采集FMC子卡

青翼自研FMC129是一款8通道125MHz采样率16位AD采集FMC子卡&#xff0c;符合VITA57.1规范&#xff0c;可以作为一个理想的IO模块耦合至FPGA前端&#xff0c;8通道AD通过高带宽的FMC连接器&#xff08;HPC&#xff09;连接至FPGA从而大大降低了系统信号延迟。 该板卡支持板上可编…

【资料分享】Xilinx Zynq-7010/7020工业评估板规格书(双核ARM Cortex-A9 + FPGA,主频766MHz)

1 评估板简介 创龙科技TLZ7x-EasyEVM是一款基于Xilinx Zynq-7000系列XC7Z010/XC7Z020高性能低功耗处理器设计的异构多核SoC评估板&#xff0c;处理器集成PS端双核ARM Cortex-A9 PL端Artix-7架构28nm可编程逻辑资源&#xff0c;评估板由核心板和评估底板组成。核心板经过专业的…

常见排序及其改进方案

常见排序及其改进方案 快速排序 思想&#xff1a; 找到一个基准&#xff0c;通常来说选取左边第一个元素 定义中间变量temp接收基准值 两个哨兵i,j分别从数组左端、右端进行扫描 (a)先从右端开始扫描&#xff1a;哨兵j先从右端开始扫描&#xff0c;确保右端元素>基准值…

Collapse折叠面板(antd-design组件库)展示所有配置选项和onChange的作用

1.Collapse折叠面板 可以折叠/展开的内容区域。 2.何时使用 对复杂区域进行分组和隐藏&#xff0c;保持页面的整洁。 手风琴 是一种特殊的折叠面板&#xff0c;只允许单个内容区域展开。 组件代码来自&#xff1a; 分页 Pagination - Ant Design 3.本地验证前的准备 参考文章【…

Jmeter(二) - 从入门到精通 - 创建测试计划(Test Plan)(详解教程)

1.简介 上一篇文章已经教你把JMeter的测试环境搭建起来了&#xff0c;那么这一篇我们就将JMeter启动起来&#xff0c;一睹其芳容&#xff0c;首先我给大家介绍一下如何来创建一个测试计划&#xff08;Test Plan&#xff09;。 2.创建一个测试计划&#xff08;Test Plan&#x…