Advertisement
xah

0011 - Project Euler

xah
Nov 23rd, 2021
985
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Go 3.75 KB | None | 0 0
  1. // 0011.go contains some functions to solve ProjectEuler.net's Problem #11
  2. // https://projecteuler.net/problem=11
  3. package main
  4.  
  5. import (
  6.     "fmt"
  7.     "strings"
  8.     "strconv"
  9. )
  10.  
  11. // MaxNumber returns the maximum number in an int array of numbers
  12. func MaxNumber(numbers []int) int {
  13.     max := 0
  14.  
  15.     for _,i := range numbers {
  16.         if i > max {
  17.             // Replace max with i
  18.             max = i
  19.         }
  20.     }
  21.    
  22.     // Return maximum number
  23.     return max
  24. }
  25.  
  26. // Make2DIntArray returns a 2D array given a multi-line string of numbers.
  27. func Make2DIntArray(numberString string) [][]int {
  28.     // Split the string by linebreaks
  29.     stringArray := strings.Split(numberString, "\n")
  30.     intArray := make([][]int, len(stringArray))
  31.  
  32.     for i,v := range(stringArray) {
  33.         // Split each line into separate strings
  34.         splitString := strings.Split(v, " ")
  35.         // Create a new array for this particular line
  36.         splitStringArray := make([]int, len(splitString))
  37.        
  38.         for j, s := range splitString {
  39.             // Convert each element to number and add to line array
  40.             splitStringArray[j],_ = strconv.Atoi(s)
  41.         }
  42.  
  43.         // Add line array to main int array
  44.         intArray[i] = splitStringArray
  45.     }
  46.  
  47.     // Return result
  48.     return intArray
  49. }
  50.  
  51. // GetMaxAdjacentProduct returns the maximum product of a number of
  52. // adjacent numbers in any direction (vertical, horizontal, diagonal)
  53. // in a 2D int array
  54. func GetMaxAdjacentProduct(adjNumbers int, intArray [][]int) int {
  55.     // Initialise variables
  56.     maxProduct := 0
  57.     x := len(intArray)
  58.     y := len(intArray[0])
  59.     var testMaxProduct int
  60.  
  61.    
  62.     for i := 0; i<x; i++ {
  63.         OUTER:
  64.         for j := 0; j<y; j++ {
  65.             // Create variables to store products of each direction
  66.             horizontal := 1
  67.             diagonal := 1
  68.             vertical := 1
  69.             revdiagonal := 1
  70.  
  71.             for k := 0; k<adjNumbers; k++{
  72.                 if j+k >= y || i+k >= x || i-k < 0 || intArray[i+k][j+k] == 0 ||
  73.                 intArray[i-k][j+k] == 0 {
  74.                     // Impossible values
  75.                     continue OUTER
  76.                 }
  77.  
  78.                 // Append to directional product values
  79.                 diagonal *= intArray[i+k][j+k]
  80.                 horizontal *= intArray[i][j+k]
  81.                 vertical *= intArray[i+k][j]
  82.                 revdiagonal *= intArray[i-k][j+k]
  83.             }
  84.  
  85.             // Get current iteration's max product number
  86.             testMaxProduct = MaxNumber([]int{diagonal, horizontal, vertical, revdiagonal})
  87.  
  88.             if testMaxProduct > maxProduct {
  89.                 // Replace max product with new highest product (this iteration)
  90.                 maxProduct = testMaxProduct
  91.             }
  92.         }
  93.     }
  94.  
  95.     // Return the max product
  96.     return maxProduct
  97. }
  98.  
  99. func main(){
  100.     // Display result
  101.     intString := `08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
  102.     49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
  103.     81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
  104.     52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
  105.     22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
  106.     24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
  107.     32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
  108.     67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
  109.     24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
  110.     21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
  111.     78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
  112.     16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
  113.     86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
  114.     19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
  115.     04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
  116.     88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
  117.     04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
  118.     20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
  119.     20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
  120.     01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48`
  121.  
  122.     fmt.Println(GetMaxAdjacentProduct(4, Make2DIntArray(intString)))
  123. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement