有人能帮我把这个例子与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);
变化是无穷的。看一下所有的答案,如果你有什么问题就告诉我们。