- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我们在测试中被问到以下问题,我不确定如何解决:
给定一组数字和一组运算符,找到生成数字的最少运算次数。
例如:
输入
set of digits: {8, 1, 6, 2, 7}
set of operations: {*, /, -}
number to be generated: 981
输出
number of operations: 2
Explanation: 981 = 16 * 62 - 11 [ 2 operations: * and - ]
限制条件:
all numbers to be used as integers
0 <= each number in set of digits <= 9
possible set of operations: { +, -, *, / } [ the division operation will always return an integer ]
0 <= number to be generated <= 999
it is necessary that while performing the operations, any of the calculated values must not exceed 999 or be negative
the precedence of operations will always be from left to right, BODMAS/PEMDAS won't be followed. For example: 16*6+2*11 will be calculated as: ((16*6) + 2) * 11
如能提供解决方案方面的任何帮助,我们将不胜感激。
我认为这个问题可以通过生成一个最接近给定数字的数字来解决,然后可以考虑生成一个新的数字问题。尽管我认为这不会产生形成给定数字所需的最少操作数。
无法编写太多代码,因为我不确定如何找到解决方案。
提前致谢!
最佳答案
我们可以将此问题视为图形问题,并使用 BFS 解决它。
首先,我们尝试在不使用任何运算符的情况下,从数字集
中创建所有可能的数字,称之为基集。这可以通过将每个数字分解为数字并检查所有这些数字是否属于数字集
来轻松实现。
for (int i = 0; i < 1000; i++){
if i can be formed by set of numbers {
add i to base set;
}
}
现在,以基集中的每个数字为起始顶点,通过对基集应用不同的算子遍历到下一个顶点
Queue q = base set
int[] distance = new int[1000];
while q is not empty{
int number = q.pop();
for(int i : base set){
for(operator : set of operators) {
int next = number operator i
if next < 1000 && next >= 0 && next not visited {
mark next as visited;
distance[next] = 1 + distance[number];
q.add(next);
}
}
}
}
return distance[target];
每个顶点都会被访问一次,所以时间复杂度是O(n ^ 2 * m)
其中n
是顶点的最大数量(这里是1000 case) 而m
是操作符的个数
关于algorithm - 给定一组数字和运算符,使用最少的运算次数形成给定的数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54196420/
为什么 (defun boolimplies (a b) (or (not a) b)) if called as(boolimplies 'a 'b) 返回 B? 即使我不使用任何 boolean
这个问题已经有答案了: Are there builtin functions for elementwise boolean operators over boolean lists? (5 个回答
我正在寻求帮助以使以下功能看起来更清晰。我觉得我可以通过使用更少的代码行来实现同样的目标。 标题看起来一定很困惑,所以让我详细说明一下。我创建了一个函数,它接受用户输入(即 72+5),将字符串拆分为
我正在学习 C++ 并尝试为矩阵编写一个 C++ 类,我在其中将矩阵存储为一维 C 数组。为此,我定义了一个 element成员函数根据矩阵元素在数组中的位置访问矩阵元素。然后我重载了 class
我正在学习 C++ 并尝试为矩阵编写一个 C++ 类,我在其中将矩阵存储为一维 C 数组。为此,我定义了一个 element成员函数根据矩阵元素在数组中的位置访问矩阵元素。然后我重载了 class
伙计们,以下内容不起作用 函数返回 true,变量返回 false,但它不会进入 when 子句。我尝试像这样放大括号 但是当我将变量的值设置为 true 并将上面的代码更改为 它进入w
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve th
我是原生 C 语言的新手,但我没有看到错误。 我尝试在这种情况下使用 if 操作: #define PAGE_A 0 #define PAGE_B 1 int pageID = 0; if (page
我正在从事一个项目,让用户鼠标滚轮移动并知道它向上或向下滚动。在我的代码中,我可以上下移动。但我想将 Action 保存到一个字符串中。例如,如果用户向上向上向下滚动'mhmh' 显示返回“UUD”但
我有一个 MySQL 表 payment我在其中存储客户的所有付款相关数据。表字段为:fileNo , clientName , billNo , billAmount , status 。我想构建一
我的表架构如下: +------+-------+-------+
我有这个(顺便说一句,我刚刚开始学习): #include #include using namespace std; int main() { string mystr; cout << "We
我正在用 bash 构建一个用于 Linux (SLES 11SP3) 的脚本。我想通过使用以下语法查找它的 pid 来检查某个进程是否存在: pid="$(ps -ef | grep -v grep
我有一个包含两列的表格; CREATE TABLE IF NOT EXISTS `QUESTION_CATEGORY_RELATION` ( `question_id` int(16) NOT N
我对 Python 如何计算 bool 语句感到困惑。 例如 False and 2 or 3 返回 3 这是如何评估的?我认为 Python 首先会查看“False and 2”,甚至不查看“or
这个问题在这里已经有了答案: 12 年前关闭。 这可能是非常基本的......但我似乎不明白: 如何 (2 & 1) = 0 (3 & 1) = 1 (4 & 1) = 0 等等.. 上面的这种模式似
无论如何在Haskell中定义如下函数? or True True = True or True undefined = True or True False
如您所知,TCL 有一些数学函数,例如 罪 , 因 , 和 假设 在 中调用的expr 带有 的命令() 大括号如下: puts [expr sin(1.57)] 现在如何使用 TCL 添加功能 li
让我们考虑两个数组列表。 ArrayList list1 = new ArrayList(); list1.add(1); list1.add(2); list1.add(3); ArrayList
我想包含和排除使用AND和OR的专业知识,包括与AND和OR操作正常工作。但是,当将排除专家与AND和OR一起使用时,返回与3相同的结果计数。我使用的是1.4版 Elasticsearch 。帮助我解
我是一名优秀的程序员,十分优秀!