- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我最近遇到了这个编码面试问题,但似乎找不到答案。这是问题。
给定一个整数数组,编写一个函数,返回组织数组所需的最小交换,使得相邻元素的绝对差都小于或等于 K。交换可以是任意两个数组元素,不一定是相邻的。
例如,
public static void main(String[] argv) {
int[] arr1 = new int[]{10, 40, 30, 20};
int K = 20;
getMinimumSwap(arr1, K); // should return 1
}
它应该返回 1 的原因是因为通过交换 40 和 30,数组将满足给定的所有相邻元素应在 20 以内的语句。
我确实尝试用谷歌搜索答案,我认为我在其他算法帮助网站上找到了一些答案,但无法获得我的问题的答案。失败的测试用例有一个数组 3, 7, 2, 8, 6, 4, 5, 1
和 K = 3
应该返回 2
.
我唯一记得的限制是输入数组的长度是1 <= n <= 8
.
最佳答案
我会将其作为图搜索问题来解决。
要将其作为图搜索问题来解决,我们首先需要定义系统的状态。在这种情况下,状态将是数字的序列。
定义状态后,每个图形搜索问题都可以完成这项工作,但由于您想要最少的交换量,我们将使用 BFS。
为方便起见,以下是在 python 中实现的,但也可以在 java 中完成。
首先我们将编写一个帮助函数,它给定一个数字序列,返回该序列所有可能的 1-swap:
def get_swaps(sequence):
swapps = collections.deque([])
ii = 0
jj = 1
done = False
while not done:
temp_seq = sequence.copy()
temp = sequence[jj]
temp_seq[jj] = sequence[ii]
temp_seq[ii] = temp
swapps.append(temp_seq)
if jj < len(sequence)-1:
jj += 1
elif ii < len(sequence)-2:
ii += 1
jj = ii + 1
else:
done = True
return swapps
请注意,这不是最佳写法,但可以解决问题。
现在我们可以按如下方式实现 BFS 算法(阅读有关 BFS 和 DFS 的更多信息 here)
def findSwap(sequence, k):
state_queue = collections.deque([]) # Pending states which have not been explored yet
visited = set()
state = (sequence, 0) # Starting state, starting sequence and 0 swapps
min_diff = max([abs(sequence[1:][ii] - sequence[:-1][ii]) for ii in range(len(sequence)-1)])
found = True
while min_diff > k:
curr_seq = state[0]
curr_count = state[1]
# Getting all swaps possible
swaps = get_swaps(curr_seq)
# Adding to the queue and to visited set all the unvisited states
for next_state in swaps:
None if tuple(next_state) in visited else state_queue.append((next_state, curr_count+1)), visited.add(tuple(next_state))
# popping next state from the queue
try:
state = state_queue.popleft()
curr_seq = state[0]
min_diff = max([abs(curr_seq[1:][ii] - curr_seq[:-1][ii]) for ii in range(len(curr_seq) - 1)])
except IndexError:
found = False
break
if found:
return state[1]
else:
return -1
在每个州我们:
在完成对所有可能的下一个状态的检查后,我们从队列中弹出下一个状态并检查最大差异。如果最大差异是 lees 那么 k 我们就完成了。如果队列为空,我们搜索了所有的状态空间,没有找到解决方案,在这种情况下,我们将返回-1
。
请注意,除了状态之外,我们还在元组中携带从原始状态到该状态的交换次数。
设置测试数组时,我们得到:
a = [3,7,2,8,6,4,5,1]
print(findSwap(a, 3)) # 2, as expected
关于java - 组织 K 内所有元素所需的最小交换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71547491/
我有一个依赖于包 B 的包 A。当包 A 中的代码运行并访问包 B 中的类时,包 B 的状态将被解析 (4),而不是 Activity (32) 和包 B 的激活器也没跑好。我认为 bundle B
这个问题在这里已经有了答案: How to remove the space between inline/inline-block elements? (41 个回答) 关闭 7 年前。
我正在尝试使用 Java OpenAL 库。我在导入名为 libsoft_oal.so 的 native 库时遇到问题。 Java OpenAL 依赖于 OpenAL 软实现。我尝试根据他们在 git
我正在尝试启动我的应用程序。是一个 unicorn +工头+sinatra的应用。 这是我的 config.ru 文件: require "rubygems" require "sinatra" Bu
我有一个下拉列表,其中包含一些从数据库表中检索的值,我想要的是当单击按钮时它应该只获得选项标签的中间值,但只有那些类名为“get_this”的选项标签并离开那些选项,如果他们没有这个类 预期输出:值
我有一个index.php文件,需要一个通用的head.php文件,head.php文件中有几个Javascript文件,当这样尝试时,代码在源代码中看起来很好,但文件却不是实际上对文档做任何事情。
有人能帮帮我吗? 我已经像这样运行了 imsmod: $ insmod /data/mm/mmdev.ko epoll_rate=100 但是我得到一个错误: insmod: init_module
是否有键盘快捷键或插件可以在 Notepad++ 中打开 PHP 所需或包含的文件?我知道,在 Dreamweaver 中,执行此操作的命令是 Ctrl+D,但我似乎无法在 Notepad++ 中找到
我已经用 js 设置了一个显示/隐藏 div,但我很难弄清楚如何一次显示一个 div。目前发生的情况是,除非我再次单击原始链接来关闭该 div,否则每个 div 都会显示。 http://www.li
当我尝试将未分配的辅助分片分配给节点时出现错误。 { "error": { "root_cause": [ { "type": "remote_transpor
我正在构建一个 C++ 应用程序,使用 Netbeans 6.9 作为我的 IDE。我有一个 C++ 库,它是一个纯 C 库的包装器。 我已将文件正确添加到项目中(使用添加库文件选项)。这是 g++
我是一名优秀的程序员,十分优秀!