我正在尝试从键盘扫描两个 vector 输入,然后创建一个函数来返回两个 vector 的标量积。但是,当我运行程序时,一旦它在第一个 for 循环中扫描了第一个 vector ,程序就结束并且标量积为 0。我不明白为什么它不让我扫描第二个 vector 。这是我的代码:
#include <stdio.h>
#include <stdlib.h>
double scalarproduct(double *v, double *w, int n){
double vw[n];
for(int i = 0; i < n; i++){
vw[i] = (v[i] * w[i]);
}
double scalprod = 0;
for(int i = 0; i < n; i++){
scalprod += vw[i];
}
return scalprod;
}
int main(){
int n;
scanf("%d", &n);
double *v;
v = (double *) malloc(sizeof(double) * n);
double *w;
w = (double *) malloc(sizeof(double) * n);
for(int i = 0; i < 0; i++){
scanf("%lf", &v[i]);
}
for (int i = 0; i < n; i++){
scanf("%lf", &w[i]);
}
printf("Scalar product=%lf\n", scalarproduct(v,w,n));
return 0;
}
输入应该是这样的:
3
1.1
2.5
3.0
1.0
1.0
1.0
然而它只允许我输入直到 3.0,然后程序跳过第二个 for 循环到 print 语句。我怎样才能解决这个问题?
最佳答案
第一个for
循环有错字:for(int i = 0; i < 0; i++)
它立即停止。
应该是:
for (int i = 0; i < n; i++) {
另请注意这些评论:
- 你应该检查
scanf()
的返回值 - 你应该检查内存分配失败
- 您不需要将单个产品存储到本地数组中,这可能会很长并且会带来问题。
- 你应该释放分配的内存。
这是一个更正和简化的版本:
#include <stdio.h>
#include <stdlib.h>
double scalarproduct(double *v, double *w, int n) {
double scalprod = 0;
for (int i = 0; i < n; i++) {
scalprod += v[i] * w[i]
}
return scalprod;
}
int main() {
int n;
if (scanf("%d", &n) == 1 && n > 0) {
double *v = (double *)malloc(sizeof(double) * n);
double *w = (double *)malloc(sizeof(double) * n);
if (v == NULL || w == NULL) {
printf("cannot allocate memory\n");
return 1;
}
for (int i = 0; i < n; i++) {
if (scanf("%lf", &v[i]) != 1) {
printf("invalid input\n");
return 1;
}
}
for (int i = 0; i < n; i++) {
if (scanf("%lf", &w[i]) != 1) {
printf("invalid input\n");
return 1;
}
}
printf("Scalar product=%f\n", scalarproduct(v, w, n));
free(v);
free(w);
}
return 0;
}
关于c - 在程序中计算标量积的第一个 'for' 循环之后,第二个 'for' 循环被忽略,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58205495/