- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
给定2个整数l和r,计算[l,r]中有多少个数字满足这些约束
1)该数字应被7整除
2)该数字至少包含三位数7
3)该数字包含的数字7比数字4多
777,774746满足这些约束,而7771,77,747474则不符合。
使用蛮力可以很容易地找到答案,但是当范围很大时,可能要花费很多时间。
我认为动态编程可以帮助解决此问题,但我想不出解决方案
有人可以给我一些指导吗?
最佳答案
从原始的暴力版本中获取:
Iterate with i over numbers between [l,r]
Use modulo to check if i is divisible by 7
Use modulo and division to get counts of digits in i
digit_count(7) >= 3
digit_count(7) > digit_count(4)
这是我想出的一些想法...
i
可除的
7
。如果我给您一个数字
x
并要求您生成可被
n
整除的数字,直到达到
y
,那么您最好这样做:
for (auto i = x + x % n; i < y; i += n)
因此,对于
7
和
l
之间
r
的倍数的情况,您需要做的就是运行
for (auto i = l + l % 7; i < r; i += 7)
循环,这会将您的暴力版本提高7倍。
l % 7 + l
)分割成数字即可。
std::vector<int>
的表达式,该表达式表示数字
[7, 7, 2, 4, 5, 7]
的
772457
数组。现在,您需要做的就是每次增加循环计数器(即
[7, 7, 2, 4, 5, 7] + 6 = [7, 7, 2, 4, 6, 3]
)时在数组内使用BCD算法。
int
s-
sevens
和
fours
。在初始化阶段,一旦将第一个数字“分解”为数组,就可以遍历该序列,并为每个
sevens
递增
7
,为每个
fours
递增
4
。而且您只需保持此数字为最新:每次更新数组时,您要为带走的每个
fours
减少
4
,并为在数组中创建的每个
4
递增。与
7
编号相同。然后,您可以比较
sevens
> = 3 &&
sevens
>
fours
并快速知道结果。
r
末尾开始工作,因此不需要调整数组的大小。也许您可以提出更多改进和调整。但是,我强烈怀疑这种解决方案可以使渐近简化。
| range | numbers f/ c2 | c2_groups | c2_total | c1_total |
| 0 - 1k | 777 | 1 | 1 | ~143 |
| 1k - 10k | _777, 7_77, 77_7, 777_ | 4 | 40 | ~1286 |
| 10k - 100k | __777, _7_77, ... | 10 | 1000 | ~12857 |
其中
numbers f/ c2
是满足条件2的数字,
c2_groups
是该数字中任意数字和7的可能组合的计数,
cx_total
是该范围内满足条件x的数字的总数。
increment [1, 0, 7, _] -> [1, 0, 8, _]
^ ^
这就是算法将在核心循环中执行的操作。然后,您可以检查当前的数字 vector 设置是否可以满足条件-例如
[0, p, _, _]
可以实现它们,而
[0, 0, p, _]
无法实现(
p
是所指向的元素)。这样,您将不断增加最高位数,而跳过许多数字。每当有可能满足要求时,您将增加偏移量并重复该过程:
push [7, 7, _, _] -> [7, 7, 0, _]
^ ^
一旦达到最低有效数字位置,您还将开始检查每个候选人的7分频。您可以尝试将数字转换为
int
并使用模或使用某种除数算法(这些使用数字,这是令人愉快的巧合)。
pop [7, 7, 7, 9] -> [7, 7, 7, _]
^ ^
现在,您将使用
increment
,看到
[7, 7, 8, _]
可以满足条件,并且再次满足
push
。然后遍历
0
,
1
,
2
,...序列,直到您进入
7
为止,看到
7787
可以使用第二和第三条件都可以,但是无法通过
7
进行除法。等等...
r
限制。我想可以通过将
r
也拆分为数字并与最高有效数字进行比较来以一种理智的方式完成。
关于c++ - 查找多少数字满足范围内的约束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33392212/
我想检索具有多个条件的数据,其中每个条件将在特定字段中包含特定关键字。 表结构如下: sid nid cid 数据 50 7 5 ee 50 7 6 AA 50 7 8 ff 51 7 5 ee 51
在 Prolog 中,我经常通过提供模板(包含变量的结构)然后满足其上的一组约束来解决问题。一个简单的例子可能是: go(T) :- T = [_, _, _], member(cat
在设计 FPGA 系统时,我如何粗略估计给定任务所需的逻辑 block 数量? 有人对我对这些常见设备的期望有一个粗略的数量级吗? 串口 使用 CRC32 的数据包解帧器 8 微核 我看过 www.o
我需要编写一段代码,如果函数满足列表中的大多数元素,则返回 True,不满足其中的 false。例如:moreThan odd [1,2,3] 是 True,但是 moreThan odd [1,2,
一旦满足三个条件,我需要使用 componentWillReceiveProps() 来调用我的组件中的方法。其中两个条件将当前 Prop 与下一个 Prop 进行比较,这两个条件通过 Ajax 请求
我正在构建一个主从表单。主视图模型构造细节 View 模型的实例。这些细节 View 模型有几个依赖项,需要用新 类实例来满足。 (这是因为他们需要在独立于主虚拟机的数据上下文中运行的服务层。) 实现
我有以下项目,我已经使用了一段时间。正如您在运行 snnipets 后看到的那样,一切正常。 /* The dark background behind the dialogs */ .dialog-
我正在尝试找出解决此问题的方法: 我想要一个函数来检查文本字段是否填充了文本并且复选框是否被选中。当满足这些条件时,“提交”按钮将启用。如果启用“提交”按钮后不久,用户清除文本字段或取消选中复选框,则
所以我相对较新,我有以下代码,我想知道如何制作这样我可以返回临时变量,同时满足java的返回要求。我希望返回临时值,但由于它位于 if-else block 内,因此从技术上讲,它不会在其外部初始化。
我正在编写一个脚本,该脚本读取文本文件并根据 .txt 文件的内容更改 div 中的文本。 但这不是我的问题。我不想要纯文本,背景颜色应该根据满足 if/elseif/else 函数的条件而改变。 v
我想在 if let 构造中满足多个约束。我知道我们可以使用“,”(逗号)来解包多个值,但它们都必须成功解包。 例如: var str: String? = "Hello" var x: Int? =
当我在 genymotion 模拟设备上安装我的应用程序时,它无法很好地安装,在控制台上我得到“INSTALL_FAILED_CPU_ABI_INCOMPATIBLE”我尝试了另一个应用程序,它安装得
因此,我试图根据数据帧的匹配条件来查看数据帧的两个变量(v1 和 v2)是否在其符号(正数或负数)中匹配变量(ID1==ID2)。 示例数据框 - Trial.df: ID1 v1
如果交付一个 Java 应用程序,它使用 gradle 依赖管理和许多来自 maven-central 的开源库,是否足以检查第一级 depedencies 的许可证(因为他们的依赖关系必须再次自动与
我正在尝试创建一个满足接口(interface) Iterable 的类“Gprogram” (这样我就可以在我的 Gprogram 中迭代 Gcommand)。但是,我只能使用类型 Iterable
我想知道是否可以获得一些帮助。 我试图在查询中写入一个查询,我使用 3 个字段:ID、选项和金额。 我需要对我的唯一 ID 进行分组,然后在该组中我需要按选项白色进行拆分,总计每个选项的金额。例如:编
如何在iOS swift项目中配置Jitsi-meet框架开启视频通话服务? 最佳答案 编辑:这也适用于 Xcode Version 12.2 (12B45b)在 Mac OS Big Sur 上。
我正在玩一些交互式菜单,目前有一个隐藏菜单,当按下一个按钮时,它会从右边出现,并将整个内容移到上面。有点像移动 facebook 应用程序。为了确定按钮应该将菜单滑出还是放回我使用 javascrip
我的目标很简单,使用遗传算法重现经典的“Hello, World”字符串。 我的代码基于此 post .代码主要包含4个部分: 生成具有多个不同个体的种群 根据与target的比较,定义评估个体好坏的
问题陈述 我们有一个雇主想要面试 N 个人,因此安排了 N 个面试时段。每个人都有这些时段的忙闲时间表。给出一个算法,如果可能的话将 N 个人安排到 N 个槽位,如果不可能则返回一个标志/错误/等。最
我是一名优秀的程序员,十分优秀!