使用指针乘以矩阵

Multiplying matrices using pointers

本文关键字:指针      更新时间:2023-10-16

嘿伙计们,我正在尝试练习学习 c++ 中的指针。 所以我正在尝试将这些数组相乘,并在我的结果矩阵中得到所有 0。 如果有人能向我暗示要看什么或对导致这种情况的原因提出一些建议,那就太神奇了。

这是代码:

#include <stdio.h>
#include<conio.h>
#include <stdlib.h>
#include <iostream>
/* Routines called. */
int loadMatrixFromFile(char *filename, int *data);
void showMatrix(int *data, int len);
int makeIdent(int matrixB[5][5], int length);
int matrixA[5][5];
int matrixB[5][5];
int matrixC[5][5];
void multiplyMatrices(int matrixA[5][5], int matrixB[5][5],int matrixC[5][5]);
int main(){
    int len, data[1000];
    len = loadMatrixFromFile("Numbers.txt", data);
    showMatrix(data, len);
    makeIdent(matrixB, len);
    multiplyMatrices(matrixA, matrixB, matrixC);
}
int makeIdent(int matrixB[5][5], int len){
    int i,j;
    int *ptr;
    ptr = &matrixB[5][5];
    printf("Matrix B is: n");
    for(i=0;i<5;i++){
           for(j=0;j<5;j++){
                 if(i==j){
                         *ptr=1;
                         printf("%d ", *ptr);
                 }
                 else{
                     *ptr=0;
                     printf("%d ",*ptr);
                 }
           }
           printf("n");
     }
    return *ptr;
     printf("n");
}
int loadMatrixFromFile(char *filename, int *data){
    FILE *in;
    int len;
    int j;
    in = fopen(filename, "r");
    if (in == NULL) {
        printf("Could not find file: %s n", filename);
    }
    else {
        printf("Reading numbers...n");
        fscanf(in, "%d", &len);
        printf("reading %d numbers from file %s ....n", len, filename);
        for(j=0;j<len;j++) {
            fscanf(in, "%d", data + j);
        }
        fclose(in);
    }
    for(int i = 0; i<5; i++){
        for(int j = 0; j < 5; j++){
                matrixA[i][j] = *(data + i*5 + j);
        }
    }
    return len;
}
void showMatrix(int *data, int len){
    int j;
    int count = 0;
    printf("Showing %d numbers from data array....n", len);
    printf("Matrix A is: n");
    for(j=0;j<len;j++) {
        printf("%d ", *(data + j));
        count++;
        if(count % 5 == 0){
            printf("n");
        }
    }
    printf("n");
}
void multiplyMatrices(int matrixA[5][5], int matrixB[5][5],int matrixC[5][5]){
     int i, n, j;
     int *ptr1, *ptr2, *ptr3;
     ptr1 = &matrixA[5][5];
     ptr2 = &matrixB[5][5];
     ptr3 = &matrixC[5][5];
     printf("n");
     printf("Matrix A x Matrix B is: n");
     for(i=0;i<5;i++){
         for(j=0;j<5;j++){
             *ptr3=0;
         }
     }
     for (i = 0; i<5; i++){
            for (j = 0; j<5; j++){
                for(n=0;n<5;n++){
                *ptr3 += (*ptr1**ptr2);
      }
                printf("%d ",*ptr3);
    }
    printf("n");
  }
}

makeIdent中,您需要在每个元素后递增ptr。自初始化ptr需要将其指向数组中的第一个元素,而不是最后一个元素。

int makeIdent(int matrixB[5][5], int len){
    int i,j;
    int *ptr;
    ptr = &matrixB[0][0]; // note the 0 instead of the 5
    printf("Matrix B is: n");
    for(i=0;i<5;i++){
           for(j=0;j<5;j++){
                 if(i==j){
                         *ptr=1; 
                         printf("%d ", *ptr);
                 }
                 else{
                     *ptr=0;
                     printf("%d ",*ptr);
                 }
                 ptr++; // this is new
           }
           printf("n");
     }
    return 0;
}

这更接近您想要的乘法矩阵:

void multiplyMatrices(int matrixA[5][5], int matrixB[5][5],int matrixC[5][5]){
 int i, n, j;
 int *ptr1, *ptr2, *ptr3;
 ptr1 = &matrixA[0][0];
 ptr2 = &matrixB[0][0];
 ptr3 = &matrixC[0][0];
 for (i = 0; i<5; i++) {
     for (j = 0; j<5; j++) {
         *ptr3 = (*ptr1 * *ptr2);
         ptr1++; ptr2++; ptr3++;
     }
 }
}

你可以这样说:

*ptr3++ = *ptr1++ * *ptr2++;

但我不想混淆这个问题。