Guest User

Untitled

a guest
Nov 18th, 2017
85
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 2.32 KB | None | 0 0
  1. #Largest product in a grid
  2.  
  3. def largest_prod_grid
  4.  
  5. number_str = "08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
  6. 49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
  7. 81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
  8. 52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
  9. 22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
  10. 24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
  11. 32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
  12. 67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
  13. 24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
  14. 21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
  15. 78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
  16. 16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
  17. 86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
  18. 19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
  19. 04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
  20. 88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
  21. 04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
  22. 20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
  23. 20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
  24. 01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48"
  25.  
  26. rows = number_str.split("\n")
  27. #p rows
  28. grid = rows.map {|r| r.split(" ")}
  29. grid = grid.map {|r| r.map {|i| i.to_i}}
  30. #p grid
  31.  
  32. final_ans = 1
  33. temp = 1
  34. step = 4
  35.  
  36. #right
  37. (0...20).each do |r|
  38. # p "ROW===== #{r}"
  39. (0...16).each do |c|
  40. temp = grid[r][c]*grid[r][c+1]*grid[r][c+2]*grid[r][c+3]
  41. if(final_ans<temp)
  42. final_ans= temp
  43. end
  44. #p "temp = #{temp}"
  45. temp = 1
  46. end
  47. end
  48.  
  49. #down ||top
  50. (0...20).each do |c|
  51. (0...16).each do |r|
  52. temp = grid[r][c]*grid[r+1][c]*grid[r+2][c]*grid[r+3][c]
  53. if(final_ans<temp)
  54. final_ans= temp
  55. end
  56. temp = 1
  57. end
  58. end
  59.  
  60. # diags
  61. (0..16).each do |c|
  62. (0..16).each do |r|
  63. temp = grid[r][c]*grid[r+1][c+1]* grid[r+2][c+2]* grid[r+3][c+3]
  64. if(final_ans<temp)
  65. final_ans= temp
  66. end
  67. end
  68. end
  69. (0..16).each do |c|
  70. (0..16).each do |r|
  71. temp = grid[r][c+3]*grid[r+1][c+2]* grid[r+2][c+1]* grid[r+3][c]
  72. if(final_ans<temp)
  73. final_ans= temp
  74. end
  75. end
  76. end
  77. final_ans
  78. end
  79. p largest_prod_grid
Add Comment
Please, Sign In to add comment