From da9921201cc6f84e938b7d92fd763ab3dfd1a8d2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Francisco=20Javier=20Couti=C3=B1o?= Date: Wed, 28 Jan 2015 14:13:06 -0600 Subject: [PATCH] p11 - Resuelto --- 11 - Mayor producto en cuadricula/p11 | Bin 10848 -> 12776 bytes 11 - Mayor producto en cuadricula/p11.cpp | 71 ++++++++++++++++++++++++++---- 2 files changed, 63 insertions(+), 8 deletions(-) diff --git a/11 - Mayor producto en cuadricula/p11 b/11 - Mayor producto en cuadricula/p11 index 5b50848623fe11843f53240176fb4264b591e9d3..af257bb659cf31878029988ccda05d85a0a0cdbf 100755 GIT binary patch literal 12776 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 delta 3690 zcmZu!4{Vdi6~FsF+xhG`iS5|f2~ax;p-DsR7(!rM#|+fv3qwsF;(SG5dHbg&LkOTwR#P)#gUn)auf7SVKaM!QBU6O_Tc_wKtd z|LBW+@80jdd++YuckeFgrt!`F9><_DM3A(WkinvX$6i}|GM9ry=Y;q;K%q5Z&&EaI z4O&O=PDvBHn4P*E9%1DXT91u=k?truoTC{X&I$33&Z{+;RI_uGIo_y2#UqhMMjv-otUC&$W)RI_&k}I^715w_i2p0z^N(oaYUZA)Ae@Fg?0b?fxi~O-SmU-`~z;)YNZ=ksbYE z|7V#DpU$~ah_0so^r`ww^=R)HXwQ!+>_yYky1O{9zVO{t_`Z5HJf^0?Q^Eqe>B*OI zTwgey_ZE5Fm&n$;mX0>fdL+H&f0<0`DtJ(vM*G6|S#Fj)iE(vPUx%qDe4pOR9tq#a zSUuspbS6@G>^yGQ1=Ogik@Q;+GMQU07z?wgqiU*tO6{wM=#KB()Shsf3a^KU^Ln3# zY>b2_aOABmBjIu0`9fcKLT$jAjH^wsnlbg_xTI3SM*9x;;@nbKhelybd1}(t5V9vc zPJ5mm&p&i=$O3-SbsU=jY$E^AtK9C|<(YkB71n~quV?vS?~Ya?e|l5-hr##Niw|V{ zsM9~a&l;^;vr2dK&;9g>^_-!y3jE@icJfXp^IhPJ?q)KZfIDD5uL6JjUM6z|__F_I zGFJ9Sdx!g_$Jq^6qXiEk(n}NuFGya2L>M@r&=%l^I%s|bzZpBO z<&C6dt$>b1m2JqREW8>dL)K~zn!dq7;~ikK!5D2z5J@rOrolJ`<0$Q#VIweuf+aC& zQ$YPDL%h z66@^-04ckZ&`R_s4eZT6m?YG%2@z`=KpJ>~5A2FtDRgM?1hmpX$oerVm+$4{8mwWI zR%p^T>r#}e&+~!9QOobLLI4ob%v*>UC3LeEWV7YEP^y}8G0EOT=oU?jsfWBAgf<6} z6Ku%sa--i|^hHS?Cd-EXHw|om!5IgowfTS)k=p!#5#V0J;)Sd7^hC)ORQZnbEq1=p zn_M_??3lFD2HQnV8%=xUXI>UvIlJZS65NY)@BX${A8&B$;*tIB313HBJlfjUyxWJ+ zzQ$-9Y3tb6+`d0fW~}Gf#1ida6Be;x(BBk`5w2Iz3BQcrSQIccwzoF1#>HP<2Au<> zwLQ9v8lL@Aj&eKsLe(f$RI0PvOzkdusutb(qFI}C2pwh!6oj3 zaWJsY`nI$pOUNgvZ8U=)+vkK{0JvT9!2UGwaC%cL@Yp;&0JsAZj87~itPMzCVcn(f zLf|<*|c{)<=qjZX;9t+rG za)`T(;Tsg_3cChqwYVXxMM|B_ToGWM6*i_;RGA|}8)4lQtEO+$E@9ixu2lpq`h0Ch zCM~P6SBVR<3QH&uT++(|)Bg<(3e+L9Bg_02{eFinzXW6T(lM-PV=pmtWx%c%4*lPo zYF1kraOh>@tavNjChSP1-!fe_Z0u5HjfEEra0V|1$zNm9k0_jlbs*}M0sen_4n?tp z9tXSRubF;Q_{8T6&xSz2qE~^4gRKkHSoE&}YQS@WH4?B(z<%vuQq>yEO)+wmvW-w;@6bso*;&n9*xSYs*kYGOiSN6H`h EKW`=K9{>OV diff --git a/11 - Mayor producto en cuadricula/p11.cpp b/11 - Mayor producto en cuadricula/p11.cpp index 5e2ecbb..87b94b4 100644 --- a/11 - Mayor producto en cuadricula/p11.cpp +++ b/11 - Mayor producto en cuadricula/p11.cpp @@ -40,12 +40,21 @@ using namespace std; #define SIZE_Y 20 #define SIZE_MAX_NUMBER 2 +int multiplyHorRight(int x, int y, int grid[SIZE_X][SIZE_Y]); +int multiplyVerDown(int x, int y, int grid[SIZE_X][SIZE_Y]); +int multiplyDiagRight(int x, int y, int grid[SIZE_X][SIZE_Y]); +int multiplyDiagLeft(int x, int y, int grid[SIZE_X][SIZE_Y]); + +int maxValue(int a, int b); + int main(int argc, char const *argv[]) { int x; int y; int grid[SIZE_X][SIZE_Y] = {0}; + long resultMax = 0; + char buffer[SIZE_MAX_NUMBER]; char *ptrBuffer; char *ptrNumeros; @@ -72,25 +81,71 @@ int main(int argc, char const *argv[]) ptrBuffer = buffer; memset(buffer,'\0',SIZE_MAX_NUMBER); - } else { *ptrBuffer++ = *ptrNumeros; } ptrNumeros++; } - //________________________________________- - //PRINT GRID - for (int i = 0; i < SIZE_Y; ++i) + //------------------------------------------ + resultMax = 0; + for (y = 0; y < SIZE_Y; ++y) { - for (int j = 0; j < SIZE_X; ++j) + for (x = 0; x < SIZE_X; ++x) { - printf("%d\t",grid[j][i]); + resultMax = maxValue(multiplyHorRight(y, x, grid), resultMax); //Validacion de Horizontal + resultMax = maxValue(multiplyVerDown(y, x, grid), resultMax); //Validacion de Vertical + resultMax = maxValue(multiplyDiagRight(y, x, grid), resultMax); //Validacion en Diagonal derecha + resultMax = maxValue(multiplyDiagLeft(y, x, grid), resultMax); //Validacion en Diagonal izquierda } - printf("\n"); } - //------------------------------------------ + printf("Resultado:\t%ld\n", resultMax); return 0; +} + + +//HORIZOTAL +int multiplyHorRight(int x, int y, int grid[SIZE_X][SIZE_Y]) +{ + return ( x+3 < SIZE_X ) ? + grid[x][y] * + grid[x+1][y] * + grid[x+2][y] * + grid[x+3][y] : 0; +} + +//VERTICAL +int multiplyVerDown(int x, int y, int grid[SIZE_X][SIZE_Y]) +{ + return ( y+3 < SIZE_Y ) ? + grid[x][y] * + grid[x][y+1] * + grid[x][y+2] * + grid[x][y+3] : 0; +} + +//DIAGONAL +int multiplyDiagRight(int x, int y, int grid[SIZE_X][SIZE_Y]) +{ + return ( x+3 < SIZE_X && y+3 < SIZE_Y ) ? + grid[x][y] * + grid[x+1][y+1] * + grid[x+2][y+2] * + grid[x+3][y+3] : 0; +} + +int multiplyDiagLeft(int x, int y, int grid[SIZE_X][SIZE_Y]) +{ + return ( x-3 >= 0 && y+3 < SIZE_Y ) ? + grid[x][y] * + grid[x-1][y+1] * + grid[x-2][y+2] * + grid[x-3][y+3] : 0; +} + +int maxValue(int a, int b) +{ + return (a >= b) ? a : b; } \ No newline at end of file -- 2.0.0