*5.23 (Demonstrate cancellation errors) A cancellation error occurs when you are
manipulating a very large number with a very small number. The large number
may cancel out the smaller number. For example, the result of 100000000.0 +
0.000000001 is equal to 100000000.0. To avoid cancellation errors and obtain
more accurate results, carefully select the order of computation. For example, in
computing the following series, you will obtain more accurate results by computing
from right to left rather than from left to right:
1+12+13+...+1n
Write a program that compares the results of the summation of the preceding series, computing from left to right and from right to left with n = 50000.
1+12+13+...+1n
Write a program that compares the results of the summation of the preceding series, computing from left to right and from right to left with n = 50000.
public class ProgrammingEx5_23 { public static void main(String[] args) { final int N = 50000; double sumL2R =0, sumR2L = 0; for(int i=1 ; i<=N; i++){ sumL2R = sumL2R+ 1.0/i; sumR2L = sumR2L+ 1.0/(N-i+1); } System.out.println("Summation from left to right:" + sumL2R); System.out.println("Summation from right to left:" + sumR2L); } }
No comments :
Post a Comment