- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
给定两个列表,例如:
a = {0, 1, 0, 1, 0, 1} - 6 个元素
b = {1, 1, 1, 0} - 4 个元素
我需要找到:最长的连续子列表的长度(由其中一个列表的一个连续片段组成) 具有相同的长度和子列表的求和元素的奇偶校验。
对于这个例子,答案是 3(“a”列表中的第 3、4、5 个元素和“b”列表中的前 3 个元素)。
列表按固定顺序排列。列表中的值是大于或等于 0 的整数。
在最坏的情况下,我的复杂度大约为 O(n^2)。这是我解决问题的方法。
Starting with the length of the longest possible sublist (in example it is 4)
while (length > 0){
(here I use "for" loop) Finding possible parities of that length or till for at least one of the lists all parities, within some of possible sublists, are found (0 and 1)
If there are in both lists, sublists of the same parity then it is the answer; break; if not: length--; }
if there hasn't been found any answer then the answer is 0
显然有更有效的方法来解决这个问题,但我想不出任何可能对我有帮助的方法。
你有什么想法吗?也许有人在这里有类似的问题,但我找不到?如果有什么需要澄清的,请告诉我。
如果问题需要澄清而不是否决投票,请要求澄清。谢谢。
编辑:这里有一些其他的例子:
a = {1, 1, 1, 1, 1, 1, 1, 1, 1, 1} - 10 个元素
b = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0} - 10 个元素
答案:10
a = {0, 0, 0, 0, 0, 0, 0} - 7 个元素
b = {0, 0, 0, 0, 0, 0, 0, 0} - 8 个元素
答案:7
a = {0, 0, 0, 1, 0, 0, 0} - 7 个元素
b = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0} - 10 个元素
答案:3
a = {0, 1, 0, 0, 1, 1, 1} - 7 个元素
b = {1, 1, 1, 0, 1, 0} - 6 个元素
答案:6
最佳答案
这里是部分答案和考虑方向。假设奇数之间的距离,即偶数的数量,o
,分布如下:
| o <- 2 -> o <- 4 -> o <- 5 -> o <- 17 -> |
请注意,我们可以利用赔率之间连续 block 的任意组合,并根据我们是否包含或排除左或右奇数元素中的一个来设置其奇偶校验。例如:
4 + 1 + 5 (±2) odd:
o <- 4 -> o <- 5 -> o
or
[exclude] <- 4 -> o <- 5 -> [exclude]
4 + 1 + 5 (+1) even:
[exclude] <- 4 -> o <- 5 -> o
or
o <- 4 -> o <- 5 -> [exclude]
但是,如果我们在任一端或两端都排除了一个奇数,那么我们就可以使用延伸到下一个奇数的范围:
[4..0] + 1 + 5 (+1) even:
[exclude] <- 4 -> o <- 5 -> o
(+1) 4 + 1 + [0..5] even:
o <- 4 -> o <- 5 -> [exclude]
所以事实上,查看我们不能达到的序列长度可能更有用,因为这些序列的数量要么小得多,要么可以快速调整范围。让我们看看您的一些示例:
{0, 1, 0, 1, 0, 1}
Odd-sum lengths we cannot reach: 4
Even-sum lengths we cannot reach: 2, 6
{1, 1, 1, 0}
Odd-sum lengths we cannot reach: None
Even-sum lengths we cannot reach: 4
{0, 1, 0, 0, 1, 1, 1}
Unreachable even-sum lengths: None
Unreachable odd-sum lengths: 7
{1, 1, 1, 0, 1, 0}
Unreachable even-sum lengths: None
Unreachable odd-sum lengths: 6
{0, 0, 0, 1, 0, 0, 0}
Unreachable even-sum lengths: > 3
Unreachable odd-sum lengths: None
{0, 0, 0, 0, 0, 0, 0, 0, 0, 0}
Unreachable even-sum lengths: None
Unreachable odd-sum lengths: All
关于algorithm - 相同长度的最长连续子列表的长度,以及子列表元素求和的奇偶性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53266878/
我正在尝试在 OCaml 中创建一个函数,该函数在数学中执行求和函数。 我试过这个: sum n m f = if n = 0 then 0 else if n > m then f
我正在尝试找到一个可以帮助我解决问题的公式。 这个公式应该对每个靠近(总是在左边)具有相同名称的单元格的单元格求和(或工作)。如下所示: 将每个大写字母视为 “食谱”并且每个小写字母为 “成分” .在
让它成为以下 python pandas DataFrame,其中每一行代表一个人在酒店的住宿。 | entry_date | exit_date | days | other_columns
我有显示客户来电的数据。我有客户号码、电话号码(1 个客户可以有多个)、每个语音调用的日期记录以及调用持续时间的列。表看起来如下示例。 CusID | PhoneNum | Date
让它成为以下 python pandas DataFrame,其中每一行代表一个人在酒店的住宿。 | entry_date | exit_date | days | other_columns
我得到了两列数据; 答: 2013年12月31日 2013年12月30日 2013年12月29日 2013年12月28日 2013年12月27日 2012年12月26日 B: 10 10 10 10
我对 double 格式的精度有疑问。 示例: double K=0, L=0, M=0; scanf("%lf %lf %lf", &K, &L, &M); if((K+L) 我的测试输入: K
我有以下数组: int[,] myArray1 = new int[2, 3] { { 1, 2, 3 }, { 4, 6, 8 } }; int[,] myArray2 = new int[2, 3
我需要有关报告查询的帮助。我在该方案的底部有一个发票表,需要一种方法来获取总计费金额,同时在此数据库方案中的较高点进行条件过滤。我需要加入其他表,这会导致 SUM 函数返回不需要的结果。 这是我正在使
我有一个使用innodb作为存储引擎的MySQL数据库,并且我有许多采用基本形式的查询: SELECT bd.billing, SUM(CASE WHEN tc.transaction_class
尝试创建一个查询来给出总胜、平和负。我有以下查询 SELECT CASE WHEN m.home_team = '192' AND m.home_full_time_score
我正在尝试生成一份报告,显示排名靠前的推荐人以及他们推荐的人产生了多少收入。 这是我的表格的缩写版本: Users Table ------------------ id referral_user_
我有以下查询,并得到了预期的结果: SELECT IF (a1>b1,'1','0') AS a1r, IF (a2>b2,'1','0') AS a2r,
我尝试了几种不同的解决方案,但都没有成功。我给出的表格是一个示例,其设计和功能与我实际使用的表格类似: PK | Color | Count -------------------
我正在尝试构建一个查询来检查我的库存。 SELECT COUNT(*) AS item_count, reseller_id, sum(sold) as sold_count, sum(refunde
我试图解决一个看起来像下面编写的代码的问题,但由于缺乏知识和阅读 sqlalchemy 文档,我还没有真正找到解决问题的方法。 目标: 如果 year_column 中的年份相同,则获取 sales_
我有一个包含一周中多天的表格。一周中的每一天都有独特的属性,例如冰淇淋是否在这一天成功送达: ID DAY_WEEK ICE_CREAM 1 Monday
首先,我有一个名为store_00的表 id | ref | item | qty | cost | sell 1 22 x1 5 10 15 2 22
我正在编写一个程序,计算每个数字的总和,直到 1000。例如,1+2+3+4+5....+100。首先,我将求和作业分配给 10 个处理器:处理器 0 得到 1-100,处理器 1 得到 101-20
我想在一个循环中一次对多个属性求和: class Some(object): def __init__(self, acounter, bcounter): self.acou
我是一名优秀的程序员,十分优秀!