C语言初阶习题(6指针)【21】打印水仙花数

1. 题目描述

求出0~100000之间的所有“水仙花数”并输出。

在这里插入图片描述

2. 思路

一开始脑袋都成浆糊了。就是我需要判断这个数字是几位数,我需要求出这个数的每一位,当时混在一起考虑根本然不清。然后就想到了分开,写一个函数单求这个数字是几位数的,单独写一个函数求这个数字的n次方。单独写一个函数来判断它是否是水仙花数。

  1. 求一个数字有几位数
    思路:小于9就是1位数,大于9开始就要计算,所以我们的条件是是否大于9,因为我们需要处理的情况是大于9的,小于9的我们默认就是1
int sizeNum(int n)
{
	int size = 1;
	while (n > 9)
	{
		n = n / 10;
		size++;
	}
	return size;
}
  1. 求一个数字的次方
    思路:这个也比较简单,需要传入两个参数,我们要求次方的数字,和要求的次方数,for循环,要求几次,乘几次
int powNum(int n,int m)
{
	int i = 0;
	if (n == 0)
	{
		return 0;
	}
	int a = 1;

	for(int i = 0;i<m;i++)
	{
		a *= n;

	}
	return a;
}
  1. 求水仙花数,这个函数就用到了上面俩函数
    思路:先调用求出我们是几位数,函数专心考虑取出我们的每一位,然后调用求次方相加
int flawerNum(int n)
{
	int sum = 0;
	int num = n;   //这里我原本是没有另外创建临时变量来接收我们传入的参数,
	//然后在if判断的时候就有问题了,我们最后还需要使用这个n的值,所以应该再创建一个局部变量
	int size = sizeNum(num);


	int i = 0;
	for (i = 0; i < size; i++)
	{
		sum += powNum(num % 10, size);
		num = num / 10;
	}
	if (n == sum)
	{
		return 1;
	}
	else
	{
		return 0;
	}

}

3. 代码实现

求0-100000的水仙花数,我们for循环,调用即可。

//求出0~100000之间的所有“水仙花数”并输出。
//“水仙花数”是指一个n位数,其各位数字的n次方之和确好等于该数本身,如:153=1 ^ 3+5 ^ 3+3 ^ 3,则153是一个“水仙花数”。
#include<stdio.h>


int sizeNum(int n)
{
	int size = 1;
	while (n > 9)
	{
		n = n / 10;
		size++;
	}
	return size;
}

int powNum(int n,int m)
{
	int i = 0;
	if (n == 0)
	{
		return 0;
	}
	int a = 1;

	for(int i = 0;i<m;i++)
	{
		a *= n;

	}
	return a;
}


int flawerNum(int n)
{
	int sum = 0;
	int num = n;   //这里我原本是没有另外创建临时变量来接收我们传入的参数,
	//然后在if判断的时候就有问题了,我们最后还需要使用这个n的值,所以应该再创建一个局部变量
	int size = sizeNum(num);


	int i = 0;
	for (i = 0; i < size; i++)
	{
		sum += powNum(num % 10, size);
		num = num / 10;
	}
	if (n == sum)
	{
		return 1;
	}
	else
	{
		return 0;
	}

}

int main ()
{

	//printf("%d ", powNum(5, 3));

	
	//printf("%d ", flawerNum(153));
	int num = 0;
	
	for (num = 0;num < 100000; num++)
	{
		if (flawerNum(num)==1)
		{
			printf("%d ",num);
		}
		
	}
	return 0;
}

在这里插入图片描述

考虑柔性负荷的综合能源系统低碳经济优化调度【考虑碳交易机制】(Matlab代码实现)内容概要:本文围绕“考虑柔性负荷的综合能源系统低碳经济优化调度”展开,重点研究在碳交易机制下如何实现综合能源系统的低碳化与经济性协同优化。通过构建包含风电、光伏、储能、柔性负荷等多种能源形式的系统模型,结合碳交易成本与能源调度成本,提出优化调度策略,以降低碳排放并提升系统运行经济性。文中采用Matlab进行仿真代码实现,验证了所提模型在平衡能源供需、平抑可再生能源波动、引导柔性负荷参与调度等方面的有效性,为低碳能源系统的设计与运行提供了技术支撑。; 适合人群:具备一定电力系统、能源系统背景,熟悉Matlab编程,从事能源优化、低碳调度、综合能源系统等相关领域研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①研究碳交易机制对综合能源系统调度决策的影响;②实现柔性负荷在削峰填谷、促进可再生能源消纳中的作用;③掌握基于Matlab的能源系统建模与优化求解方法;④为实际综合能源项目提供低碳经济调度方案参考。; 阅读建议:建议读者结合Matlab代码深入理解模型构建与求解过程,重点关注目标函设计、约束条件设置及碳交易成本的量化方式,可进一步扩展至多能互补、需求响应等场景进行二次开发与仿真验证。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值