问题:您将得到两个整数数组,并要求您确定满足以下两个条件的所有整数:
第一个数组的元素是所考虑的整数的所有因子所考虑的整数是第二个数组的所有元素的因子这些数字被称为介于两个数组之间。您必须确定存在多少这样的数字。
例如:样本输入
2 3
2 4
16 32 96
样本输出
3
我的代码:
public static int getTotalX(int n, int m, List<Integer> a, List<Integer> b) {
int total=0,x=0,y=0;
for(int i=a.get(n-1);i<=b.get(0);i++)
{
for(int j=0;j<n;j++)
{
//to check if the elements in list 'a' can divide the integer.
if(i%a.get(j)==0)
{
y++;
}
}
//if every element in list a can divide the integer go forward
if(y==n)
{
for(int k=0;k<m;k++)
{
//to check if the elements of list 'b' is divisible by integer
if(b.get(k)%i==0)
{
x++;
}
}
y=0;
//if every element of 'b' is divisible by integer, count how many such integers are there
if(x==m)
{
total++;
x=0;
}
}
}
return total;
}
我的代码没有给出正确的解决方案,我不明白为什么。
3条答案
按热度按时间ki1q1bka1#
很大的进步。你已经很接近了。算法准确有效。
只有一个错误:您正在重置
if
条件中的变量x
和y
。如果条件不为真,那么变量永远不会被重置,并且所有未来的计算都是在
x
和y
中的错误值上进行的。像Java8一样吗?下面是一个一行程序:
avwztpqn2#
我的Python解决方案
sg3maiej3#