- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
在一个面试题中,我得到了一个稍微不同版本的分区和问题:给你一个数组,找到分区索引,使得左数组的和等于右数组的和。在这里,我们不能打乱元素以形成分区
例如:[5,1,8,2,2,9,1]
5 + 1 + 8 = 2 + 2 + 9 + 1 = 14
9 + 5 = 8 + 2 + 2 + 1 + 1 但这不是这个问题的有效答案,因为我们不能打乱元素。
我说我们可以做一个左和右和,左数组和右数组。从 leftsum = 5(第一个元素的总和)和 right sum = 23(所有其他元素的总和)开始。然后遍历右数组并继续检查左和=右和。如果不是,则减去右数组中的第一个元素并将其添加到左数组中。在这里,它是左和 = 5 + 1 = 6,右和 = 23 - 1 = 22。
同样:左和 = 6 + 8 = 14,右和 = 22 - 8 = 14由于 leftsum = rightsum,我们将分区索引返回为 2
如果我们到达正确数组的末尾,则意味着该分区不存在,我们返回无效。
尽管面试官说答案似乎是正确的,但他似乎对我的解决方案并不满意。这个问题有更有效的解决方案吗?
最佳答案
你的算法的时间/空间复杂度是最优的,但是:
此类问题的部分目的是了解您还问了哪些问题。在这种情况下,您可以询问(如果尚未指定)是否:
当您提到 left 和 right 数组时,您给人的印象是该解决方案处理 2 个单独的数组变量。此外,从 中减去 和添加到 数组可以加强您在更改两个不同数组的大小时分配和释放内存的想法。这效率不高,甚至可以解释为使用 O(n) 空间。
您的解决方案使用了两个总和,而它可以用一个总和来完成。
一个关键观察结果是,如果所有值的总和为 n,则分区的总和应为 n/2。如果您有一个分区具有该总和,那么显然另一个分区也具有该总和。此外,如果保证值是整数,n 应该是偶数。如果这很奇怪,您可以停止进一步寻找,因为没有解决方案。
所以有符号整数的算法可以这样表示:
sum = 0
for i = 0 to len(array)-1:
sum = sum + array[i]
if sum % 2 == 1:
return -1 # no solution
sum = sum / 2
for i = 0 to len(array)-1:
if sum == 0:
return i # solution
sum = sum - array[i]
return -1 # no solution
查看它在 repl.it 上运行
注意可以有多个解决方案(例如输入 [0,0,0,0]
或 [5,-1,1,-1,1,-1,1,-1 ,1,5]`).该算法将只返回它找到的第一个。
如果假定值始终为非负数,那么您可以使用此算法,它可以运行得更快一些(但时间复杂度不会不同),因为它只访问数组值一次:
sum = 0
left = 0
right = len(array) - 1
while left <= right:
if sum < 0:
sum = sum + array[left]
left = left + 1
else:
sum = sum - array[right]
right = right - 1
if sum = 0:
return left # solution
return -1 # no solution
查看它在 repl.it 上运行
关于algorithm - 没有洗牌的分区总和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41706063/
这是一个面试问题。请给一些提示: 使用 vector 实现一个方法,洗一副牌。 public class Card { private int value; Card(int v) {
我非常是 C++ 的新手,我还没有完全理解基本概念,但我的教授希望我们编写一个算法来洗牌和展示一副纸牌和一副牌需要表示为二维数组。 但是我在模拟一副纸牌时遇到了麻烦! #include #inclu
我想用 php 创建随机桥牌的集合。我认为我可以将一副有序的纸牌编码为下面的字符串 $deal(考虑到大写和小写时,我喜欢它有 52 个字母)。我发现了 php 函数 str_shuffle。所以我想
我想随机重新排序矩阵 A 的行以生成另一个新矩阵。如何在 R 中做到这一点? 最佳答案 使用 sample()以(伪)随机顺序生成行索引并使用 [ 重新排列矩阵. ## create a matrix
我计划在 android-Java 上开发一个简单的纸牌游戏,在我的应用程序中,我洗牌,所以我想知道将我的牌组存储在数组或堆栈中的最佳方法是什么..?堆栈的唯一问题是我不知道如何对其进行洗牌。 最佳答
我正在尝试创建一种方法,使用 Arraylist 随机打乱基元数组。我想知道 .get(); 方法是否是在我的 Arraylist 上使用的正确方法,在 for 循环中的普通数组上它只是 array[
我是 C++ 的新手,但是,我正在尝试创建一些盐和胡椒噪音。它几乎完成了,只是在这之间我想洗牌一个整数数组,无论我做什么,无论我使用什么洗牌功能,我总是得到令人讨厌的“从这里需要”,它没有告诉我任何事
我被要求编写一个程序(主要是一个方法)来洗牌。我编写了以下程序: public class Deck { //////////////////////////////////////// // Dat
我已经看到其他与此相关的话题,但似乎没有一个能回答我的问题。我尝试在 vector 上使用 shuffle() 函数,但我一直收到错误消息: deck_of_cards.cpp:34:5: error
是否与sort 一致导致更随机的数组或者是 sort这里只是浪费? use List::Util qw(shuffle); @random1 = shuffle sort keys %vocables
首先,这个问题是从 this 中摘下来的问题。我这样做是因为我认为这部分比较长问题的子部分更大。如有冒犯,请见谅。 假设您有一个生成随机性的算法。现在你如何测试它?或者更直接地说 - 假设您有一个洗牌
我正在制作一个配对游戏,其中有 8 个 ImageView 和 4 个不同的图像。我想知道页面何时加载是否可以交换 ImageView 的位置? 让每张图片的顺序每次都变? 最佳答案 试试这个:
我正在制作一款纸牌游戏,需要在游戏开始前洗牌。通过在将数组插入数据库之前对其进行混洗,可以毫无问题地完成此操作。然而,在游戏开始后,有些情况下玩家需要洗牌。我想到的唯一方法是重新洗牌后重新插入套牌,但
我正在运行一个网站,其中用户导航子目录的唯一方式是通过随机页面(类似于维基百科的随机页面功能)。我已经实现了调用随机页面的代码并且它工作正常,但我想尽量减少在 onclick 执行后再次调用同一页面的
我想用一个条件打乱一个 2d Numpy 数组。例如,仅随机播放非零值。 import numpy as np a = np.arange(9).reshape((3,3)) a[2,2] = 0 #
我将如何获取 RLMArray 并对其进行洗牌,以便 RLMArray 中的当前项目是随机的。 我已经查看了 RLMArray 的文档,但是我没有看到对其进行洗牌的好方法。 最佳答案 你最好的选择可能
在我的 Qt c++ 应用程序中,我有一个包含一组 QString 值的 QStringList!我想随机播放(任意更改 QStringList 中 QString 的位置)。 perl中是否有任何默
我知道它是如何工作的,但我在排序和配对方面仍然有问题,这样我才能确定获胜者。 将它们配对(配对是具有相同值(value)的卡片。)例如,红心 A 和黑桃 A 组成一对。然后我数那些对。拥有最高对子的手
我有一组这样的 div: 我需要在点击其中一个红色 div 时随机播放它们,但点击的 div 应该始终与黄色 div 交换。 fiddle here $('.box-red').click(funct
// deck of cards // below are initializations #include #include #include using namespace std; int
我是一名优秀的程序员,十分优秀!