算法系统学习-水仙fa数是啥花?(蛮力算法补充)

简介: 该系列是基于有一定语言基础(C,C++,Java等等)和基本的数据结构基础进行的算法学习专栏,如果觉得有点吃力 😥 ,建议先了解前提知识再学习喔!本个专栏会将用更容易理解的表达去学习算法,如果在一些表述上存在问题还请各位多多指点

水仙花数问题:


有个比较经典的问题,就是水仙花数问题,简单来说就一个三位数,它的各位数字的立方和等于其本身,比如153=1^3+5^3+3^3

Case1:现在要求输出所有在m和n范围内的水仙花数


算法分析:

首先水仙花必须是三位数,那么为数据的范围自然而然是【100,999】,可知每个数都是三位数,那只需要令a,b,c分别等于三个数,然后求出它们的立方和是否等于这个三位数,如果是则就是水仙花数。那只需要枚举这个区间内所有的数,统计水仙花数的个数即可。


算法如下:

main(){
  int m,n,I,a,b,c,d=0,k;
    while(cin>>m>>n){
    if(n<m){
    i=n;
        n=m;
        m=i;
    }
    }
    for(i=m,d=0;i<=n;i++){
      a=i%10;//取出个位
        b=(i/10)%10;//取出十位
        c=i/100;//取出百位
        if(a*a*a+b*b*b+c*c*c=i){
            d++;
        }
    for(i=m,k=0;i<=n;i++){
        a=i%10;//取出个位
        b=(i/10)%10;//取出十位
        c=i/100;//取出百位
        }   
        if(a*a*a+b*b*b+c*c*c=i){
          cout<<i;k++;
            if(k<d){
            cout<<"";
            }
        }
     if(d==0){
            cout<<"no"<<endl;
        }    
    }
}


完数问题


完数的定义:如果一个大于1的正整数的所有因子之和等于它的本身,则称这个是完数,比如6 =1+2+3 既是6的因子,这些因子之和也是等于6,再比如28=1+2+4+7+14

Case2:判断两个数正整数之间完数的个数

算法分析:

根据定于预处理的枚举出1-10000以内的完数有哪些,然后用各数ans【i】存1~i以内的完数个数,这样就可以直接判断某个区间内的完数个数。 比如区间【a,b】那答案就是ans【b】-ans【a-1】

算法设计:

#define mm 1009
int ans[mm]
bool is_ok(int m){
int sum=0;
int ms=(int) sqrt((float)m)+1;//o枚举m的除1以外的每个因子
for(int i=2;i<ms;i++){
  if(m%i==0){
    sum+=i+m/i;
    }
    sum++;//如果所有因子的和等于这个数m,就说明m为完数
if(sum==m){
return true;
}eles{
return false;
  }
  }
}
main(){
ans[1]=1;//ans[i] 表示1~i有多少个完数
for(int i=1;i<10000;i++){
if(is_ok(i))
ans[i]=ans[i-1]+1;
else ans[i]=ans[i-1];
int cas,a,b;
  cin>cas;
while(cas--){
  cin>>a>>b;
if(a>b){
  int z;
  z=b;
  a=b;
  b=z;
    }
  cout<<ans[b]-ans[a-1];
  }
}

其实这类问题更多是数学思维上的考察,算法设计并不难,但是如何将数学问题转化成算法设计的核心,如何找到对运行效率要求较高的大规模的数据处理问题时,必须要多动动脑筋,因此冰冻三尺非一日之寒。

目录
相关文章
|
1月前
|
数据采集 边缘计算 算法
遗传算法+多目标规划算法+自适应神经模糊系统(Matlab代码实现)
遗传算法+多目标规划算法+自适应神经模糊系统(Matlab代码实现)
|
2月前
|
机器学习/深度学习 算法 数据挖掘
没发论文的注意啦!重磅更新!GWO-BP-AdaBoost预测!灰狼优化、人工神经网络与AdaBoost集成学习算法预测研究(Matlab代码实现)
没发论文的注意啦!重磅更新!GWO-BP-AdaBoost预测!灰狼优化、人工神经网络与AdaBoost集成学习算法预测研究(Matlab代码实现)
|
8天前
|
机器学习/深度学习 运维 算法
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
|
16天前
|
机器学习/深度学习 自然语言处理 算法
基于改进鲸鱼优化算法的微网系统能量优化管理研究(Matlab代码实现)
基于改进鲸鱼优化算法的微网系统能量优化管理研究(Matlab代码实现)
|
27天前
|
机器学习/深度学习 算法 算法框架/工具
256KB内存约束下的设备端训练:算法与系统协同设计——论文解读
MIT与MIT-IBM Watson AI Lab团队提出一种创新方法,在仅256KB SRAM和1MB Flash的微控制器上实现深度神经网络训练。该研究通过量化感知缩放(QAS)、稀疏层/张量更新及算子重排序等技术,将内存占用降至141KB,较传统框架减少2300倍,首次突破设备端训练的内存瓶颈,推动边缘智能发展。
114 6
|
2月前
|
机器学习/深度学习 边缘计算 算法
【状态估计】基于LMS类自适应滤波算法、NLMS 和 LMF 进行系统识别比较研究(Matlab代码实现)
【状态估计】基于LMS类自适应滤波算法、NLMS 和 LMF 进行系统识别比较研究(Matlab代码实现)
101 3
|
16天前
|
机器学习/深度学习 存储 算法
基于模型预测算法的混合储能微电网双层能量管理系统研究(Matlab代码实现)
基于模型预测算法的混合储能微电网双层能量管理系统研究(Matlab代码实现)
|
2月前
|
机器学习/深度学习 人工智能 算法
【多智能体编队】基于自适应控制算法非线性输入的多智能体系统编队控制研究(Matlab代码复现)
【多智能体编队】基于自适应控制算法非线性输入的多智能体系统编队控制研究(Matlab代码复现)
|
3月前
|
算法 数据可视化 数据挖掘
基于EM期望最大化算法的GMM参数估计与三维数据分类系统python源码
本内容展示了基于EM算法的高斯混合模型(GMM)聚类实现,包含完整Python代码、运行效果图及理论解析。程序使用三维数据进行演示,涵盖误差计算、模型参数更新、结果可视化等关键步骤,并附有详细注释与操作视频,适合学习EM算法与GMM模型的原理及应用。
|
5月前
|
存储 监控 算法
基于 C# 的局域网计算机监控系统文件变更实时监测算法设计与实现研究
本文介绍了一种基于C#语言的局域网文件变更监控算法,通过事件驱动与批处理机制结合,实现高效、低负载的文件系统实时监控。核心内容涵盖监控机制选择(如事件触发机制)、数据结构设计(如监控文件列表、事件队列)及批处理优化策略。文章详细解析了C#实现的核心代码,并提出性能优化与可靠性保障措施,包括批量处理、事件过滤和异步处理等技术。最后,探讨了该算法在企业数据安全监控、文件同步备份等场景的应用潜力,以及未来向智能化扩展的方向,如文件内容分析、智能告警机制和分布式监控架构。
134 3

热门文章

最新文章