Diskuze: extremy v alokovane matici
V předchozím kvízu, Online test znalostí C++, jsme si ověřili nabyté zkušenosti z kurzu.

Neregistrovaný

Zobrazeno 9 zpráv z 9.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí C++, jsme si ověřili nabyté zkušenosti z kurzu.
Mozes pouzit nieco taketo:
typedef struct{
double max;
double min;
} MaxMin;
MaxMin get_maxmin(double** matrix, unsigned md, unsigned nd){
MaxMin maxmin;
maxmin.max = maxmin.min = matrix[0][0];
for(unsigned i=0;i<md;i++){
for(unsigned j=0;j<nd;j++){
if(matrix[i][j] > maxmin.max)maxmin.max=matrix[i][j];
if(matrix[i][j] < maxmin.min)maxmin.min=matrix[i][j];
}
}
return maxmin;
}
Už mi to hlasí jen jednu chybu. Celý tento algoritmus jsem hodil tesne
před dealokaci. k vypsání na obrazovku bude stačit jen napsat po tomto
algoritmu
: printf("maxin");?
Ten moj kod deklaruje strukturu MaxMin a funkciu get_maxmin. Pouziva sa takto:
MaxMin maxmin = get_maxmin(xd, md, nd);
printf("\n max = %lf, min = %lf", maxmin.max, maxmin.min);
takže jsem to doplnil a nekde tam je jeste chyba:-( už to dělam 3 dny a tady na tom jsem se zasekl nejvic.u toho maxima a minima...
//dynamicka alokace matice (2 rozmer. pole) pomoci pointeru na pointer
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#include<math.h>
#include <time.h>
#include <iostream>
void main()
{
srand((unsigned)time(NULL)); /* Inicializace generátoru */
int i,j;
int index_i,index_j;
printf("\n\nDYN. ALOKACE matice md x nd pomoci POINTERU na POINTER .\n\n");
int md,nd;
do{//zadani poctu radku
printf("\nZadej pocet radku v rozmezi 1 az 20\nmd = ");
scanf("%d",&md);
}while(md<1 || md>20);
do{//zadani poctu sloupcu
printf("\nZadej pocet sloupcu v rozmezi 1 az 20\nnd = ");
scanf("%d",&nd);
}while(nd<1 || nd>20);
double **xd;
//alokace pameti pro vektor md pointeru, jez vyuzijeme pro alokaci jednotlivych radku
xd = (double **) malloc(md*sizeof(double*));
//alokace pameti pro jednotlive radky
for(i=0;i<md;i++) xd[i] = (double *) malloc(nd*sizeof(double) );
for(i=0;i<md;i++)
for(j=0;j<nd;j++)
xd[i][j]=rand()%100;
printf("\nVypis matice\n\n");
for(i=0;i<md;i++)
{
for(j=0;j<nd;j++)
printf("[%d][%d]=%4.2lf ",i,j,xd[i][j]=rand()%100);
printf("\n");
}
typedef struct{
double max;
double min;
} MaxMin;
MaxMin get_maxmin(double** matrix, unsigned md, unsigned nd){
MaxMin maxmin;
maxmin.max = maxmin.min = matrix[0][0];
for(unsigned i=0;i<md;i++){
for(unsigned j=0;j<nd;j++){
if(matrix[i][j] > maxmin.max)maxmin.max=matrix[i][j];
if(matrix[i][j] < maxmin.min)maxmin.min=matrix[i][j];
}
}
return maxmin;
}
printf("\n max = %lf, min = %lf", maxmin.max, maxmin.min);
//Dealokace
for(i=0;i<md;i++) free(xd[i]);//nejprve uvonime pamet po jednotlivych radcich
free(xd); //nakonec uvolnime pamet kterou zabiral vektor md ukazatelu na jednotlive radky
getch();
}
Zobrazeno 9 zpráv z 9.