36 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Swift
		
	
	
		
		
			
		
	
	
			36 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Swift
		
	
	
|  | // MathUtils.swift | ||
|  | // Mathematical utility functions | ||
|  | // Corresponds to MathUtils.kt in Android implementation | ||
|  | 
 | ||
|  | import Foundation | ||
|  | 
 | ||
|  | public class MathUtils { | ||
|  |     private static let _fibonacciArray: [Int] = [ | ||
|  |         1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233, 377, 610, 987, 1597, 2584, 4181, 6765, 10946, | ||
|  |         17711, 28657, 46368, 75025, 121393, 196418, 317811, 514229, 832040, 1346269, 2178309, 3524578, | ||
|  |         5702887, 9227465, 14930352, 24157817, 39088169, 63245986, 102334155, 165580141, 267914296, | ||
|  |         433494437, 701408733, 1134903170, 1836311903, 2971215073 | ||
|  |     ] | ||
|  |      | ||
|  |     public static func fibonacci(_ n: Int, offset: Int = 0) -> Int64 { | ||
|  |         let len = _fibonacciArray.count | ||
|  |         let idx = n + offset | ||
|  |          | ||
|  |         if idx < len { | ||
|  |             return Int64(_fibonacciArray[idx]) | ||
|  |         } | ||
|  |          | ||
|  |         var n1 = Int64(_fibonacciArray[len - 2]) | ||
|  |         var n2 = Int64(_fibonacciArray[len - 1]) | ||
|  |         var sum: Int64 = 0 | ||
|  |          | ||
|  |         for _ in len..<idx { | ||
|  |             sum = n1 + n2 | ||
|  |             n1 = n2 | ||
|  |             n2 = sum | ||
|  |         } | ||
|  |          | ||
|  |         return sum | ||
|  |     } | ||
|  | } |