产生大于N的Smith数
实验三 求Smith数
实验目的:
通过本次实验,掌握穷举算法的基本思想。
实验环境:
硬件:PC机
软件:windows操作系统,C语言
实验内容:
若一个合数的质因数分解式逐位相加之和等于其本身逐位相加之和,则称这个数为Smith数。给定一个正整数N,求大于N的最小Smith数。
实验学时:2
实验过程:
1.算法设计
设计一个寻找大于N的最小史密斯数,首先这个史密斯数必须大于N,不能为素数。
构造一个int isPrime(int x)函数,来判断这个数是不是素数。
构造一个int everySum(int x)函数,来计算这个数每个位相加的和。
构造一个int isSmith(int n)函数,调用上面两个函数来判断是否符合史密斯数的条件来判断这个数是不是史密斯数。
主函数调用isSmith(int n)函数得到函数值,并且规定输入‘0’的时候程序结束。
2.程序清单
#include <stdio.h>
#include <math.h>
//判断是否为素数
int isPrime(int x)
{
int i,num = ;
for(i = ; i < x; i++)
{
if( x % i == )
{
num = -;
break;
}
}
if(num == )
return ;
else
return ;
}
//计算每一位相加的和
int everySum(int x)
{
int sum = ;
while(x > ) {
sum += x % ;
x /= ;
}
return sum;
}
//判断是否为smith数
int isSmith(int n)
{
int i,b = n;
int num[],x = ;
int sum = ;
while( !isPrime(n))
{
for(i = ; i < n; i++)
{
if( isPrime(i) && n % i == )
{
num[x] = i;
x++;
break;
}
}
n /= i;
}
num[x] = n;
for( i = ; i <= x; i++)
{
sum += everySum(num[i]);
}
if(sum == everySum(b))
return ;
else
return ;
}
//主函数
int main()
{
int num;
int flag = ;
while((scanf("%d",&num) != EOF) && (num != ))
/*
EOF,为End Of File的缩写,通常在文本的最后存在此
字符表示资料结束。在本句中表示若输入'0'表示字符结束。
*/
{
flag = ;
for(int i = num + ; ; i++)
{
if( isSmith(i) )
{
printf("%d\n",i);
flag ++;
}
if(flag == )
{
break;
}
}
}
return ;
}
3.运行结果
实验总结:
通过这次实验,学会了怎样判断一个数是否为Smith数和它的判断条件,以及它的算法程序设计,用递归的方法写出了程序,以后要多利用递归算法,将大问题划分为小问题,优化程序设计。
产生大于N的Smith数的更多相关文章
- [LeetCode169]Majority Element求一个数组中出现次数大于n/2的数
题目: Given an array of size n, find the majority element. The majority element is the element that ap ...
- [算法]在数组中找到出现次数大于N/K的数
题目: 1.给定一个整型数组,打印其中出现次数大于一半的数.如果没有出现这样的数,打印提示信息. 如:1,2,1输出1. 1,2,3输出no such number. 2.给定一个整型数组,再给 ...
- 在数组中寻找出现次数大于N/K的数
给定一个int[]数组,给定一个整数k,打印所有出现次数大于N/k的数,没有的话,给出提示信息. === 核心思想:一次在数组中删除K个不同的数,不停的删除,直到剩下的数的种类不足K就停止删除,那么如 ...
- 《程序员代码面试指南》第八章 数组和矩阵问题 在数组中找到出现次数大于N/K 的数
题目 在数组中找到出现次数大于N/K 的数 java代码 package com.lizhouwei.chapter8; import java.util.ArrayList; import java ...
- Smith数的判断
题目描述: smith数是指满足下列条件的可分解的整数: 其所有位数上的数字和等于其全部素数因子的数字之和. 例如,9975是smith数,9975=3*5*5*7*19,即9975的数字和=因子的数 ...
- scala基础题--100以内的数求和,求出当和第一次大于20的当前数【for】
import util.control.Breaks._ object work01 { def main(args: Array[String]): Unit = { //方式一 var sum:I ...
- 找到数组中频次大于1/k的数
Majority Number III 给定一个数组(长度为L),找到所有出现频次大于1/k的数字. 我们主要使用摩尔投票法(Voting Algorithm)结合Map的数据结构解决此问题.其时间复 ...
- Excel 中将大于511的十进制数转换成二进制
If number < -512 or if number > 511, DEC2BIN returns the #NUM! error value. 所以不能直接使用DEC2BIN函数. ...
- [2014亚马逊amazon] 在线笔试题 大于非负整数N的第一个回文数 Symmetric Number
1.题目 如标题,求大于整数N(N>=0)的第一个回文数的字符串表示形式. 这个题目也是当时笔试第一次见到,花了一个小时才做出了.慢慢总结还是挺简单的. 2.分析 分析如下: (1)一位数N(9 ...
随机推荐
- npm 加速之 yarn cnpm pnpm
npm 加速之 yarn cnpm pnpm 有没有感觉到使用 npm 的时候很慢? 安装速度 几Kb/s 不说, 还装着装着出错了, 奇奇怪怪的问题.这种情况大多数还是因为网络的原因, 很多时候虽然 ...
- SpringMVC返回值响应
1.响应数据和结果视图 1.1 搭建环境 New Module -> Module SDK 1.8 -> Create from archetype -> maven-archety ...
- CKA认证考试题
1.列出环境中所有的pv,并以name字段排序(使用kubectl自带排序功能) kubectl get pv --sort-by=.metadata.name 2.列出制定pod的日志中状态为err ...
- abort exit _exit return的区别
exit()函数导致子进程的正常退出,并且参数status&这个值将被返回给父进程.exit()应该是库函数.exit()函数其实是对_exit()函数的一种封装(库函数就是对系统调用的一种封 ...
- mac ffmpeg mediainfo视频压缩
最近在开发官网,官网上放了一些视频,但是本宝宝拿到的都是100多.200多.300多兆的原视频,怎么把他们变成统统20兆呢?宝宝用了如下方法,很好用哟- 1.安装视频压缩工具下载ffmpeg brew ...
- flutter本地环境的安装以及编辑器的配置
由于本文图片比较多,所有都缩小了不少,点击图片就可以放大看到原始图片 使用镜像 cmd打开终端,贴上以下代码,以加入到环境变量中,如果添加失败,可以手动添加 export PUB_HOSTED_URL ...
- openstack keystone 总结
1.OpenStack组件 OpenStack是一个开源的云计算管理平台项目,由几个主要的组件组合起来完成具体工作.OpenStack是一个不断发展的系统,在它的发展历程之中,它的组件个数在增加,服务 ...
- 洛谷P1434滑雪讲解
题源:[戳这里] 洛谷博客链接:[戳这里] 我觉得这道题主要方法应该有两种: 动态规划 搜索 下面会分别对这两种方法进行简述 一,动态规划法首先的想法是用L(i,j)表示从点(i,j)出发能到达的最长 ...
- centos实现三个节点高可用
centos实现三个节点高可用 使用的资源为keepalived和nginx 高可用主机IP地址 192.168.136.131 192.168.136.133 192.168.136.134 ngi ...
- C语言基础知识---认识C语言
2019.11.09 秋风 晴 最近一直在搞一套LoRa算法.总算有点效果了.心感慰藉(可能用错词语.但是也不管了) 初学者如何理解C语言? 无需刻板理解,笔者常用一个这样的例子助学生理解:法国人和法 ...