Fahad/Scala/Chapter5.sc
changeset 32 fa92e8f089a2
parent 30 197babb05539
child 42 6b8e3d232361
equal deleted inserted replaced
31:238c98db6057 32:fa92e8f089a2
    26     if (a > b) 0 else powerOfTwo(a) + sumPowersOfTwo(a + 1, b)
    26     if (a > b) 0 else powerOfTwo(a) + sumPowersOfTwo(a + 1, b)
    27 
    27 
    28   sumPowersOfTwo(2, 4)
    28   sumPowersOfTwo(2, 4)
    29   */
    29   */
    30 
    30 
       
    31   /*
    31   def sum(f: Int => Int, a: Int, b: Int): Int =
    32   def sum(f: Int => Int, a: Int, b: Int): Int =
    32     if (a > b) 0 else f(a) + sum(f, a + 1, b)     //> sum: (f: Int => Int, a: Int, b: Int)Int
    33     if (a > b) 0 else f(a) + sum(f, a + 1, b)
    33 
    34 
    34   //def sumInts(a: Int, b: Int): Int = sum(id, a, b)
    35   //def sumInts(a: Int, b: Int): Int = sum(id, a, b)
    35   //def sumInts(a: Int, b: Int): Int = sum((x: Int) => x, a, b)
    36   //def sumInts(a: Int, b: Int): Int = sum((x: Int) => x, a, b)
    36   def sumInts(a: Int, b: Int): Int = sum(x => x, a, b)
    37   def sumInts(a: Int, b: Int): Int = sum(x => x, a, b)
    37                                                   //> sumInts: (a: Int, b: Int)Int
       
    38   //def sumSquares(a: Int, b: Int): Int = sum(square, a, b)
    38   //def sumSquares(a: Int, b: Int): Int = sum(square, a, b)
    39   //def sumSquares(a: Int, b: Int): Int = sum((x: Int) => x * x, a, b)
    39   //def sumSquares(a: Int, b: Int): Int = sum((x: Int) => x * x, a, b)
    40   def sumSquares(a: Int, b: Int): Int = sum(x => x * x, a, b)
    40   def sumSquares(a: Int, b: Int): Int = sum(x => x * x, a, b)
    41                                                   //> sumSquares: (a: Int, b: Int)Int
       
    42   def sumPowersOfTwo(a: Int, b: Int): Int = sum(powerOfTwo, a, b)
    41   def sumPowersOfTwo(a: Int, b: Int): Int = sum(powerOfTwo, a, b)
    43                                                   //> sumPowersOfTwo: (a: Int, b: Int)Int
       
    44   
    42   
    45   def id(x: Int): Int = x                         //> id: (x: Int)Int
    43   def id(x: Int): Int = x
    46 	def square(x: Int): Int = x * x           //> square: (x: Int)Int
    44 	def square(x: Int): Int = x * x
       
    45 	*/
    47 	def powerOfTwo(x: Int): Int = if (x == 0) 1 else 2 * powerOfTwo(x - 1)
    46 	def powerOfTwo(x: Int): Int = if (x == 0) 1 else 2 * powerOfTwo(x - 1)
    48                                                   //> powerOfTwo: (x: Int)Int
    47                                                   //> powerOfTwo: (x: Int)Int
    49                                                   
    48   
       
    49 
    50   // 5.2: Currying
    50   // 5.2: Currying
       
    51 
       
    52   def sum(f: Int => Int): (Int, Int) => Int = {
       
    53     def sumF(a: Int, b: Int): Int =
       
    54       if (a > b) 0 else f(a) + sumF(a + 1, b)
       
    55     sumF
       
    56   }                                               //> sum: (f: Int => Int)(Int, Int) => Int
       
    57 
       
    58   def sumInts = sum(x => x)                       //> sumInts: => (Int, Int) => Int
       
    59   def sumSquares = sum(x => x * x)                //> sumSquares: => (Int, Int) => Int
       
    60   def sumPowersOfTwo = sum(powerOfTwo)            //> sumPowersOfTwo: => (Int, Int) => Int
    51   
    61   
    52   
    62   sumSquares(1,10) + sumPowersOfTwo(10,20)        //> res0: Int = 2096513
    53   
    63   sum(x => x * x)(2,4)                            //> res1: Int = 29
    54   
    64 
       
    65 	// 5.3: Finding Fixed Points of Functions
       
    66 	
       
    67 	val tolerance = 0.001                     //> tolerance  : Double = 0.001
       
    68 	def isCloseEnough(x: Double, y: Double) = Math.abs((x-y) / x) < tolerance
       
    69                                                   //> isCloseEnough: (x: Double, y: Double)Boolean
       
    70 	def fixedPoint(f: Double => Double)(firstGuess: Double) = {
       
    71 		def iterate(guess: Double): Double = {
       
    72 			val next = f(guess)
       
    73 			if (isCloseEnough(guess, next)) next
       
    74 			else iterate(next)
       
    75 		}
       
    76 		iterate(firstGuess)
       
    77 	}                                         //> fixedPoint: (f: Double => Double)(firstGuess: Double)Double
       
    78 	
       
    79 	
       
    80 	
       
    81 	
       
    82 	
       
    83 	
       
    84 	
       
    85 	
       
    86 	
       
    87 	
       
    88 	
       
    89 	
       
    90 	
       
    91 	
       
    92 	
       
    93 	
       
    94 	
       
    95 	
       
    96 	
       
    97 	
       
    98 	
       
    99 	
       
   100 	
       
   101 	
       
   102 	
       
   103 	
       
   104 	
       
   105 	
    55 }
   106 }