有人能帮我把这个例子与C中的for循环相乘吗?
好,
我以char数组为例

 x[]={ '0','3','0','8','9','6','4','3','8','4','0','0','7' };

* 765432,765432

我需要多重元素:
ZZZ=(0*7)+(3*6)+(0*5)+(8*4)+(9*3)+(6*2)+(4*7)+(3*6)+(8*5)+(4*4)+(0*3)+(0*2)=
 0 +18 + 0 +32 +27 +12 +28 +18 +40 +16 +0 +0 = 191

你怎么认为:
我试过:
int mnozi = 0;

for (i = 0; i < 12; i++) {
    //mnozi = (int)p[i]-48;
    for (int j = 7; j > 1; j--)
        mnozi = ((int)p[i] - 48) *j;
        printf("\n%d", mnozi);

        ZZZ = ZZZ + mnozi;
    }

还有一些奇怪的输出!

最佳答案

有很多方法可以将数组乘以重复两次的递减7-2模式。一种是简单地使用指针在模式的两次迭代中向下遍历。它可以通过多种方式进行编码,另一种方式是:

#include <stdio.h>

int main (void) {

    char x[]={ '0','3','0','8','9','6','4','3','8','4','0','0','7' }, *p = x;
    int i = 7, r = 0, z = 0;

    for (; *p && p < x + sizeof x; p++) {
        printf (" %d * %d = %d\n", *p - '0', i, (*p - '0') * i);
        z += (*p - '0') * i--;
        if (i < 2) { i = 7; if (++r > 1) break; }
    }

    printf ("\n z : %d\n\n", z);

    return 0;
}

示例使用/输出
$ ./bin/multcharray

 0 * 7 = 0
 3 * 6 = 18
 0 * 5 = 0
 8 * 4 = 32
 9 * 3 = 27
 6 * 2 = 12
 4 * 7 = 28
 3 * 6 = 18
 8 * 5 = 40
 4 * 4 = 16
 0 * 3 = 0
 0 * 2 = 0

 z : 191

通过限制应用乘法的x中的字符来限制迭代的微小变化可以是:
    char x[]={ '0','3','0','8','9','6','4','3','8','4','0','0','7' }, *p = x;
    int i = 7, z = 0;

    for (; *p && p < x + sizeof x - 1; p++) {
        z += (*p - '0') * i;
        printf (" %d * %d = %d\n", *p - '0', i, (*p - '0') * i);
        if (--i < 2) i = 7;
    }

    printf ("\n z : %d\n\n", z);

变化是无穷的。看一下所有的答案,如果你有什么问题就告诉我们。

10-04 21:57
查看更多