Здравсвуйте. уже обращался с этой программой, мне помогли и обьяснили, но входе долгого тестрирования (придирчивый преподаватель) обнаружилось, что работает программа не совсем корректно (то правильно считает, то нет). Плюс потребовался ввод-вывод из/в файл. Перепробовал несколько вариантов, но не срастается. Поэтому снова обращаюсь за помощью.
По заданию нужно: вводится матрица с элементами вещественного типа(клавиатруа или файл), подсчитывается характеристика каждой строки(характеристикой считаем среднее арифметическое всех элементов). После этого выводится(на экран, в файл или сразу и туда и туда) новая матрица, в которой строки упорядочены в порядке роста их характеристик(подсчет характеристик и сортировка производятся в отдельной функции).
Прошу же вот о чем. Нужно добавить в код программы саму функцию на место пустующей void matrica_b(в самом конце).
Код | #include <stdio.h> #include <malloc.h> void matrica_b (double **,double **,int,int); void main() { FILE *mat=fopen("mat.dat","r"); FILE *rez=fopen("rez.rez","w"); int i,k,j,l,t; double **a,**b; printf("vvedite kolichestvo strok matrici:"); scanf("%d",&k); printf("vvedite kolichestvo stolbchov matrici:"); scanf("%d",&l); a=calloc(k,sizeof(double*)); for (i=0;i<k;i++) a[i]=calloc(l,sizeof(double)); b=calloc(k,sizeof(double*)); for (i=0;i<k;i++) b[i]=calloc(l,sizeof(double)); do { printf("vvod matrici s klaviaturi(1)\nvvod matrici iz faila(2)"); scanf("%d",&t); } while (t!=1 && t!=2); for (i=0;i<k;i++) for (j=0;j<l;j++) { if (t==1) {
printf("\nvvedite %d %d element massiva A:",i,j); scanf("%lf",&a[i][j]); } if (t==2) fscanf(mat,"%lf",&a[i][j]); }
matrica_b(a,b,k,l); do { printf("\nvivesyi rezultati na ekran(1)"); printf("\nvivesyi rezultati v fail(2)"); printf("\nvivesyi rezultati na ekran i v fail(3)"); scanf("%d",&t); } while (t!=1 && t!=2 && t!=3); for (i=0;i<k;i++) { printf("\n"); fprintf(rez,"\n"); for (j=0;j<l;j++) b[i][j]=matrica_b(); if (t==1) { if (i==0) printf(" Matrica A: Matrica B:\n"); for (j=0;j<l;j++) printf(" %.3lf",a[i][j]); printf(" "); for (j=0;j<l;j++) printf(" %.3lf",b[i][j]); } if (t==2) { if (i==0) fprintf(rez," Matrica A: Matrica B:\n"); for (j=0;j<l;j++) fprintf(rez," %.3lf",a[i][j]); fprintf(rez," "); for (j=0;j<l;j++) fprintf(rez," %.3lf",b[i][j]); } if (t==3) { if (i==0) { printf(" Matrica A: Matrica B:\n"); fprintf(rez," Matrica A: Matrica B:\n"); } for (j=0;j<l;j++) { printf(" %.3lf",a[i][j]); fprintf(rez," %.3lf",a[i][j]); } printf(" "); fprintf(rez," "); for (j=0;j<l;j++) { printf(" %.3lf",b[i][j]); fprintf(rez," %.3lf",b[i][j]); } } } fclose(mat); fclose(rez); free(a); for (i=0;i<k;i++) free(a[i]); free(b); for (i=0;i<k;i++) free(b[i]);
} void matrica_b (double **a,double **b,int k,int l) {
}
|
Заранее спасибо всем, кто откликнется на просьбу нуба |