| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 534 人关注过本帖
标题:一道关于数学的算法题
只看楼主 加入收藏
geekbo
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2009-10-24
结帖率:0
收藏
已结贴  问题点数:20 回复次数:2 
一道关于数学的算法题
有三个整数,X,A,B,和另外一个整数D.

X*D中的任何一个digit必须大于A小于B;

例子:
X=6;

A=1;B=50;

D=2468;

所以X可以乘以2,4,6,8,24,26,28,82,246,684....每个D里的数字组成数,其实D是以个集合{2,4,6,8},但是输入时是以 2468 形式的整数一次输入的。

这个例子的输出是 4;因为只有2,4,6,8乘以X在范围以内,82,24,26,28都太小。当然也可能会太小,如果A输入的值是20的话,2*6就小于20,也不合格。

希望能给好的解法
搜索更多相关主题的帖子: 算法 数学 
2009-10-24 12:45
cosdos
Rank: 9Rank: 9Rank: 9
来 自:ShangHai
等 级:蜘蛛侠
威 望:6
帖 子:2109
专家分:1385
注 册:2007-6-19
收藏
得分:20 
max: 最大取值
min: 最小取值

max = B / X;  if(B % max == 0) --max;
if (A / X >= 0) min = (A / X) + 1;

计算min到max之间的,集合D中数字的组合。

[ 本帖最后由 cosdos 于 2009-10-24 16:08 编辑 ]

—>〉Sun〈<—
2009-10-24 16:03
geekbo
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2009-10-24
收藏
得分:0 
回复 2楼 cosdos
怎么比较min和max之间D的数
2009-10-24 18:40
快速回复:一道关于数学的算法题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025810 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved