You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					20 lines
				
				757 B
			
		
		
			
		
	
	
					20 lines
				
				757 B
			| 
											3 years ago
										 | 
 | ||
|  | Exercise 1.17: The exponentiation algorithms in
 | ||
|  | this section are based on performing exponentiation by means of repeated
 | ||
|  | multiplication.  In a similar way, one can perform integer multiplication by
 | ||
|  | means of repeated addition.  The following multiplication procedure (in which
 | ||
|  | it is assumed that our language can only add, not multiply) is analogous to the
 | ||
|  | expt procedure:
 | ||
|  | 
 | ||
|  | 
 | ||
|  | (define (* a b)
 | ||
|  |   (if (= b 0)
 | ||
|  |       0
 | ||
|  |       (+ a (* a (- b 1)))))
 | ||
|  | 
 | ||
|  | This algorithm takes a number of steps that is linear in b.  Now suppose
 | ||
|  | we include, together with addition, operations double, which doubles an
 | ||
|  | integer, and halve, which divides an (even) integer by 2.  Using these,
 | ||
|  | design a multiplication procedure analogous to fast-expt that uses a
 | ||
|  | logarithmic number of steps.
 |