- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
虽然看到这个问题会很奇怪,但我在继续我的编码之旅时确实需要理解一些核心概念。我在 Hackerrank 上遇到了一个问题,它类似于 DIVISIBLE SUM PAIRS
无论如何,我都会在这里给出问题陈述:
问题陈述
给定一个数组,我们必须找到可被给定数字 k 整除的对的数量,并且还有一个条件,即:这些对中的 arr[i] < arr[j]。
示例
例如,ar=[1,2,3,4,5,6]
和k=5
。我们符合标准的三对是 [1,4] [2,3]
和[4,6]
.
代码
在发布我的代码之前,我想告诉您我的代码已经通过了所有测试用例,并且可以接受下一个挑战,但是我正在尝试解决一个小问题,在代码中。
static int divisibleSumPairs(int n, int k, int[] ar) {
int count = 0;
for(int i=0; i<ar.length; i++){
for(int j=i+1; j<ar.length; j++){
if(((ar[i]+ar[j])%k)==0){
if(i < j)
count++;
}
}
}
return count;
}
当我这样做时 if(i < j) count++
,它给了我正确的结果,但是一旦我这样做 if(ar[i] < a[j]) count++
,据说它给了我一个错误的答案。
任何人都可以帮我解决这个问题,比如剩下的吗?因为我知道支票arr[i] < arr[j]
应该给出正确的结果。我不想继续使用错误的知识。
编辑
自从我明白我做错了什么。我在代码中进行了一项编辑,即不以 1 启动内部循环,因为每次内部循环完成时它都会以 1 开始,然后再次运行。我感谢所有帮助我理清这一点并使我的概念足够强大以处理此类问题的人。
我个人感谢Mike 'Pomax' Kamermans , Ricola ,和xerx593消除了我的疑虑并为我提供了循环元素的核心概念。这对我以后会有帮助,我不会再重复那样的事情了。 :)
最佳答案
我刚刚检查了您的链接,问题陈述中给出的条件是
Find and print the number of (i,j) pairs where i < j and ar[i] + ar[j] is divisible by k.
这只是 unordered pairs 的数字总和可被 k 整除的元素的个数。
不管你怎么写
there is one more condition to it, which is : the arr[i] < arr[j] from those pairs.
我好像你误解了这个问题。它解释了为什么 i<j
条件有效,而 arr[i] < arr[j]
没有。
现在您知道您只需要无序对,无需迭代 j
来自1
至ar.length
。既然你需要j > i
,每j
之间1
和i
(包括在内)是没有用的。您可以将代码简化为:
static int divisibleSumPairs(int n, int k, int[] ar) {
int count = 0;
for(int i=0; i<ar.length-1; i++){
for(int j=i+1; j<ar.length; j++){
if(((ar[i]+ar[j])%k)==0){
count++;
}
}
}
return count;
}
关于java - 可整除和对,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54187896/
这就是我到目前为止所拥有的;我必须使用这个主要方法。 public class HW4 { public static boolean isDivisibleByThree(String n)
这个问题在这里已经有了答案: Is floating point math broken? (31 个答案) 关闭 7 年前。 我不明白为什么 % 会这样: >>> 5 % 0.5 == 0 Tru
目录 整除 整除的定义与基本性质 素数 素数的定义与基本性质
我正在编写一个 C 程序,要求用户输入密码并检查数字中的每个数字是否可以被 2 整除。例如,如果他们输入 123452,它会告诉用户这是错误的,因为 1, 2,3,5 不能被 2 整除。如果我输入 6
我有一些东西要读取一个文本文件,然后是一个像这样的函数文件 int Myiseven(int x) { int isOdd = 0; if (x % 2 == 1) {
我需要编写一个程序,在给定的数字范围内,程序需要找到数字之和能被3整除的数字。之后,它需要检查总和是否大于0,如果它能被4整除,并打印满足上述条件的数字。这是我尝试过的: include int m
我对 ffmpeg 有疑问。我想将图像序列格式化为视频。我为此使用以下命令: ffmpeg -framerate 24 -i image%04d.jpeg Project.mp4 -vf "pad=c
我把这个作业作为家庭作业,但我不知道该怎么做: Input is a string of the numbers 1, 2 and 3. You need to build a function th
这里我需要检查数字中的每个数字,因为范围应该被3整除,这意味着当我输入20和40时,代码需要验证20到40之间数字的每个数字,并且它应该显示 30,33,36,39 我试图做的是获取代码的最后一位数字
Given an array of integers and a number k, write a function that returns true if given array can be
如果用户输入从最高位到最低位的数字,如何检查二进制数是否可以整除 13? 位数可能非常大,因此将其转换为十进制然后检查其可整除性是没有意义的。 我已经以常规方式处理了它。位数最多为 10^5,因此在将
我正在解决这个问题,即我们给了数字 N,它可以很大,最多可以有 100000 个数字。 现在我想知道找到这些数字的最有效方法是什么,我认为在大数字中我最多需要删除 3 位数字才能被 3 整除。 我知道
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicate: Check if a number is divisible by 3 如果一个二进制数的个数是偶数,它是否
我想知道二进制有没有除以3的整除法则 例如:在十进制中,如果数字和除以 3,则数字除以 3。例如:15 -> 1+5 = 6 -> 6 除以 3所以 15 除以 3。 要了解的重要一点是,我不是在寻找
这工作正常,但我想让它更漂亮 - 并容纳所有可被 4 整除的值: if i==4 || i==8 || i==12 || i==16 || i==20 || i==24 || i==28 || i==
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度理解。包括尝试过的解决方案、为什么它们不起作用,以及预
如何判断一个变量是否可以被 2 整除?此外,如果是,我需要执行一个功能;如果不是,我需要执行另一个功能。 最佳答案 使用模数: // Will evaluate to true if the vari
处理器中的除法需要很多时间,所以我想问一下如何以最快的方式检查数字是否可以被其他数字整除,在我的情况下,我需要检查数字是否可以被 15 整除。 我也一直在浏览网页并发现 有趣 方法来检查数字是否可以被
我一直在学习可变参数模板,在 this excellent blog post 的帮助下,我已经设法编写了一个函数模板 even_number_of_args 它返回它接收到的参数的数量是否可以被 2
我的一个 friend 在对一家公司进行在线评估时遇到了这个问题,并向我提出了这个问题。 An array of integers is given and we have to (possibly)
我是一名优秀的程序员,十分优秀!