我被要求在C中创建一个程序,其中将采用2d数组。 3个数字,每次都会找到一个数字的持久性乘以它直到我们只有一个数字。然后,每个数字的结果将存储在数组的第二行。
例如
例如,数字2736的持久性为0:首先我们找到2 * 7 * 1 * 6 = 252
,然后是2 * 5 * 2 = 20
,最后是2 * 0 = 0
,我们得到一位数。 (在该示例中为0)。
数组的数字将来自txt文件,格式如下:
2716 2720
因此数字将为[2716,2720] : 2176 2177 2178 2179 21720
每个持久性的图形表示都是
Number | Persist
-----------------
2716 | 3
2717 | 4
2718 | 2
2719 | 3
2720 | 1
以及之后的数组:
array[5][2] = { {2716,3}, {2717,4}, {2718,2}, {2719,3}, {2720,1} };
所以最后我需要找到maxinum persistanse的数字(在我的例子中是2717)并将其打印到一个名为persist.out的txt文件中,其行和列如下:
2717 4
我的问题是复制数组的最后一部分。
此外,我们需要检查多个数字是否具有更大的持久性,然后找到最大数量。
我为最后一部分编写了一个代码但是不是很稳定,我无法进行我想要的检查。
已更新!
#include <stdio.h>
int multiply_digits(int x)
{
int z = 1;
while ( x )
{
z *= x % 10;
x /= 10;
}
return z;
}
int main() {
int a;
int b;
FILE *input, *output;
input = fopen("persist.in","r");
fscanf(input,"%d %d",&a, &b);
fclose(input);
int c = (b - a) + 1;
int array[c][2];
array[0][0] = a;
for(int i = 1; i < c; i++)
{
array[i][0] = a + i;
}
int i, j;
for (i=0; i< c; ++i)
{
int n = array[i][0];
int j = 0;
while (n>9)
{
n = multiply_digits(n);
j++;
}
array[i][1] = j;
}
for (i = 0; i < c; i++)
{
for (j = 0; j < 2; j++)
{
printf("%d ", array[i][j]);
}
printf("\n");
}
printf("\n");
int indexOfMaximum;
int maximum = array[0][1];
for (i = 0 ; i < c ; ++i )
{
if ( array[i][1] >= maximum ) {
maximum = array[i][1];
indexOfMaximum = i;
}
}
}
答案 0 :(得分:2)
在for
循环中,您的停止条件为i <= c
,因为您的起始索引为i < c
0
您的数组被声明为int array[c][2]
所以您正在读取数组的末尾我假设垃圾值实际上可能大于maximum
,如果您想要达到{{1}然后声明c
。
至于将其写入文件部分只需执行
int array[1 + c][2]
希望它对你有所帮助。
答案 1 :(得分:1)
您需要将最后一个if语句中的条件更改为&gt; =以便实际获得最大值。使用您的代码,如果更多的持久性出现多次,您将只找到第一个。
if ( array[i][1] >= maximum ) {
maximum = array[i][1];
indexOfMaximum = i;
}