Sto provando a scrivere 2 funzioni, una per leggere la matrice (array 2D) e un'altra per stamparla. Finora ho:Creazione di un array 2D mediante puntatore/malloc, quindi stamparlo
/* Read a matrix: allocate space, read elements, return pointer. The
number of rows and columns are given by the two arguments. */
double **read_matrix(int rows, int cols){
double **mat = (double **) malloc(sizeof(double *)*rows);
int i=0;
for(i=0; i<rows; i++){
/* Allocate array, store pointer */
mat[i] = (double *) malloc(sizeof(double)*cols);
//what to do after??
return mat;
}
allora la funzione della matrice di stampa, non è sicuro se è corretto
void print_matrix(int rows, int cols, double **mat){
for(i=0; i<rows; i++){ /* Iterate of each row */
for(j=0; j<cols; j++){ /* In each row, go over each col element */
printf("%f ",mat[i][j]); /* Print each row element */
}
}}
e qui è la funzione principale che sto usando per eseguire:
#include <stdio.h>
#include <stdlib.h>
double **read_matrix(int rows, int cols);
void print_matrix(int rows, int cols, double **mat);
void free_matrix(int rows, double **mat);
int main(){
double **matrix;
int rows, cols;
/* First matrix */
printf("Matrix 1\n");
printf("Enter # of rows and cols: ");
scanf("%d %d",&rows,&cols);
printf("Matrix, enter %d reals: ",rows*cols);
matrix = read_matrix(rows,cols);
printf("Your Matrix\n"); /* Print the entered data */
print_matrix(rows,cols,matrix);
free_matrix(rows, matrix); /* Free the matrix */
return 0;}
Le votazioni per chiudere perché sembra una domanda per la revisione del codice StackExchange invece di StackOverflow. Il codice sembra fondamentalmente buono, però. –
Qual è il tuo problema esatto? Non vedo nessuna domanda qui ... – Christoph
@BenJackson: è chiuso come [offtopic sul review.stackexchange] (http://codereview.stackexchange.com/q/17833/6143). Non è una bella esperienza. – jfs