From e91191bac51ca876db8467c6295e007cb8cbdb0b Mon Sep 17 00:00:00 2001 From: Santo Cariotti Date: Fri, 15 Nov 2019 18:47:46 +0100 Subject: Ex 1 - 28 Gennaio 2019 Scrivere un metodo che prenda in input una matrice quadrata A di numeri interi ed un double w, e restituisca il valore booleano true se il rapporto tra il minimo ed il massimo valore della diagonale secondaria di A `e minore o uguale a w. --- I_anno/Programmazione_1/ex1_28_01_19.cc | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 I_anno/Programmazione_1/ex1_28_01_19.cc diff --git a/I_anno/Programmazione_1/ex1_28_01_19.cc b/I_anno/Programmazione_1/ex1_28_01_19.cc new file mode 100644 index 0000000..a027e82 --- /dev/null +++ b/I_anno/Programmazione_1/ex1_28_01_19.cc @@ -0,0 +1,30 @@ +#include +#include +#include + +using namespace std; + +template +bool func(int (&A)[N][N], double w) { + vector l; + for(int i = N-1, j = 0; j < N; --i, j++) { + l.push_back(A[i][j]); + } + + auto min_max = minmax_element(begin(l), end(l)); + + return (static_cast(*min_max.first)/static_cast(*min_max.second)) <= w; +} + +int main() { + int A[3][3] = { + {1, 2, 3,}, + {67, 10, 56}, + {10, 0, 1}, + }; + + cout << func(A, 0.2) << endl; // False + cout << func(A, 0.4) << endl; // True + + return 0; +} -- cgit v1.2.3-18-g5258