实验三  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数的更多相关文章

  1. [LeetCode169]Majority Element求一个数组中出现次数大于n/2的数

    题目: Given an array of size n, find the majority element. The majority element is the element that ap ...

  2. [算法]在数组中找到出现次数大于N/K的数

    题目: 1.给定一个整型数组,打印其中出现次数大于一半的数.如果没有出现这样的数,打印提示信息. 如:1,2,1输出1.    1,2,3输出no such number. 2.给定一个整型数组,再给 ...

  3. 在数组中寻找出现次数大于N/K的数

    给定一个int[]数组,给定一个整数k,打印所有出现次数大于N/k的数,没有的话,给出提示信息. === 核心思想:一次在数组中删除K个不同的数,不停的删除,直到剩下的数的种类不足K就停止删除,那么如 ...

  4. 《程序员代码面试指南》第八章 数组和矩阵问题 在数组中找到出现次数大于N/K 的数

    题目 在数组中找到出现次数大于N/K 的数 java代码 package com.lizhouwei.chapter8; import java.util.ArrayList; import java ...

  5. Smith数的判断

    题目描述: smith数是指满足下列条件的可分解的整数: 其所有位数上的数字和等于其全部素数因子的数字之和. 例如,9975是smith数,9975=3*5*5*7*19,即9975的数字和=因子的数 ...

  6. scala基础题--100以内的数求和,求出当和第一次大于20的当前数【for】

    import util.control.Breaks._ object work01 { def main(args: Array[String]): Unit = { //方式一 var sum:I ...

  7. 找到数组中频次大于1/k的数

    Majority Number III 给定一个数组(长度为L),找到所有出现频次大于1/k的数字. 我们主要使用摩尔投票法(Voting Algorithm)结合Map的数据结构解决此问题.其时间复 ...

  8. Excel 中将大于511的十进制数转换成二进制

    If number < -512 or if number > 511, DEC2BIN returns the #NUM! error value. 所以不能直接使用DEC2BIN函数. ...

  9. [2014亚马逊amazon] 在线笔试题 大于非负整数N的第一个回文数 Symmetric Number

    1.题目 如标题,求大于整数N(N>=0)的第一个回文数的字符串表示形式. 这个题目也是当时笔试第一次见到,花了一个小时才做出了.慢慢总结还是挺简单的. 2.分析 分析如下: (1)一位数N(9 ...

随机推荐

  1. Houdini Python开发实战 课程笔记

    P2 + P3 + P4 + P5 - 基础: 1. Houdini中使用Python的地方 2. Textport:可使用cd.ls等路径操作的命令(命令前加%,可在python中使用) 3. So ...

  2. rtmp_specification_1.0

    Copyright Adobe Systems Incorporated H. Parmar, Ed. M. Thornburgh, Ed. Adobe December 21, 2012 Adobe ...

  3. 递归下降和LL(1)语法分析

    什么是自顶向下分析法 在语法分析过程中一般有两种语法分析方法,自顶向下和自底向上,递归下降分析和LL(1)都属于是自顶向下的语法分析 自顶向下分析法的过程就像从第一个非终结符作为根节点开始根据产生式进 ...

  4. 【记录】【mysql】的REPLACE()用法

    操作前数据 操作 UPDATE `test_replace` SET PASSWORD ') WHERE id REPLACE(PASSWORD, '1', '77')意思就是password中的1替 ...

  5. Vue项目引入百度地图

    先去百度开放平台申请ak.http://lbsyun.baidu.com/ 进来之后 按照步骤走,先登录百度账号,然后申请成为开发者,然后申请ak密钥 填写完毕后提交,会给你邮箱发个激活邮件 点击申请 ...

  6. mysql连接不释放

    环境: 持久层:JPA 数据库连接池:druid 数据库中间件:Mycat 数据库:Mysql 报错: Unable to acquire JDBC Connection 排查步骤: 方法一: 1.d ...

  7. elasticsearch插件

    bigdisk安装: 1.下载地址http://bigdesk.org/,注意和elasticsearch的版本对应关系 2.将文件上传到服务器elasticsearch的plugin目录下,解压 3 ...

  8. linux 文件夹分享

    1.在 linux 安装 samba,安装好之后 配置文件在 /etc/samba/smb.conf 目录下. yum install samba samba-client(yum install s ...

  9. Compact Middle Packages

    idea工具进行Java开发,在项目视图,默认是将package层级以简洁显示的,如下图: 但有时,我们希望不要使用这种模式,比如:某个父包下,有一个子包,想在父包下,增加一个包,可是来时增加在子包下 ...

  10. 去掉a标签点击后的虚边框

    a { cursor: pointer; text-decoration: none; hide-focus: expression(this.hideFocus=true); outline: no ...