c++ - 使用数组查找 HCF,得到未知输出 (C++)

标签 c++ arrays sorting

所以无论我输入什么,我最后一次输出时都会得到结果 176。
我的逻辑是我可以制作一个 Array(comfactors) 并在其中放置公因数。之后,我取最大的数放在comfactors[0]中输出。
如果其他人有任何其他建议,请告诉。一直在寻找学习。

#include <iostream>
using namespace std;
typedef int integer;
void generate_factors(integer factor1[], int a, integer factor2[], int b);
void findHCF(int[], int[], int, int);
int main()
{
int x, y;

cout << "Enter first integer: " << endl;
cin >> x;

cout << "Enter second integer: " << endl;
cin >> y;



integer *integerArray1 = new integer[x], *integerArray2 = new integer[y];

generate_factors(integerArray1, x, integerArray2, y);
findHCF(integerArray1, integerArray2, x, y);

return 0;
}

void generate_factors(integer factor1[], int a, integer factor2[], int b)
{
int i, j;
cout << "\n" << endl;
cout << "Factors of " << a << " are: " << endl;
for (i = 1; i <= a; i++)
{
    if ((a%i) == 0)
    {
        factor1[i - 1] = i;
        cout << factor1[i - 1] << " ";
    }

}

cout << "\n" << endl;

cout << "Factors of " << b << " are: " << endl;
for (j = 1; j <= b; j++)
{
    if ((b%j) == 0)
    {
        factor2[j - 1] = j;
        cout << factor2[j - 1] << " ";
    }

}


}

void findHCF(integer Array1[], integer Array2[], int a, int b)
{
int i, j, k;
int comfactors[1024];

for (i = 0; i <= a; i++) 
{
    for(j = 0; j <= b; j++)
    {

        if (Array1[j] == Array2[i]) 
        {
            comfactors[i] = i;
        }

    }

}


for (k = 0;k < a+b; ++k)
{
    if (comfactors[0] < comfactors[k])
    {
    comfactors[0] = comfactors[k];}
}
cout << "\n\nThe Highest Common Factor is " << comfactors[0];
}

最佳答案

你得到了错误的答案,因为这里你的数组在随机点填充了 garbade 值, 例如,在您的函数 generate_factors 中,只有满足条件的那些点才会被填充。因此,当您在函数 findHCF 中搜索公共(public)值时,这些垃圾值就会出现并导致意外输出的发生。 所以你应该用 1 初始化数组

尽管计算两个数的 HCF 的一种简单方法是使用 Euclid 算法

这是欧几里德算法在 C++ 中的实现:

int hcf(int a, int b) {
   if (b == 0) {
      return a;
   } else {
      return hcf(b, a % b);
   }
}

关于c++ - 使用数组查找 HCF,得到未知输出 (C++),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47565456/

相关文章:

c++ - 对象数组作为链表中的字符数组——我关于对齐的假设是否有效?

c++ - 跟随发出的信号到其连接的插槽?

javascript - 对数组进行排序,并将重复项插入新数组

python - 如何使用未知数组维度进行 numpy 组合切片和数组索引

python - 对嵌套元组列表进行排序

c++ - 对 `Example::Note::~Note()' protobuf 的 undefined reference

c++ - 递增可变输入迭代器是否会使旧迭代器值无效?

c++ - 总线错误 :10 with more indexes to go

java - 如何在 hibernate 中使用条件对列表进行排序

java - 无法理解我的书如何计算算法步骤