Computer Science 523
Advanced Programming

Summer 2014, The College of Saint Rose

GeometricFractionalSum BlueJ Project

Click here to download a BlueJ project for GeometricFractionalSum.


GeometricFractionalSum Source Code

The Java source code for GeometricFractionalSum is below. Click on a file name to download it.


GeometricFractionalSum.java

/*
 * Example GeometricFractionalSum: compute the sum of
 * 1/2 + 1/4 + 1/8 + ... up to some fixed number of terms.
 * The larger that number, the closer we get to the sum
 * of the infinite series, which is 1
 *
 * Jim Teresco, The College of Saint Rose, CSC 202, Fall 2012
 *
 * $Id: GeometricFractionalSum.java 2366 2014-05-20 02:33:22Z terescoj $
 */

import java.util.Scanner;

public class GeometricFractionalSum {

    public static void main(String[] args) {

        // a Scanner to read in our number
        Scanner keyboard = new Scanner(System.in);

        // read in the number of terms we want to compute
        int numTerms = 0;
        while (numTerms <= 0) {

            System.out.print("How many terms of the 1/2 + 1/4 + 1/8 + ... sequence should we compute? ");
            numTerms = keyboard.nextInt();

            if (numTerms <= 0) {
                System.out.println("Please enter a positive number...");
            }
        }

        // Now we need to compute our sum.  So we will need a variable where
        // that sum will be accumulated.
        double sum = 0.0;

        // the first term we will add in, this will be halved each time
        // around the loop so we are ready to add in the next smaller term.
        double nextTerm = 0.5; 

        // And a loop that counts up to the number of times we wish to "go
        // around the loop" and add another term.  Very often, counting loops
        // intending to go around "n" times will count from 0 to n-1, using
        // a form like this.

        for (int count = 0; count < numTerms; count++) {
            
            // add in the next term
            sum += nextTerm;
            
            // print some information about our running sum
            System.out.println("Added term " + nextTerm + ", sum now " + sum);
            
            // update nextTerm, so if we go around again, we'll add in a
            // smaller number
            nextTerm /= 2;
        }
        
        // we're done!  nothing really more to print here.
    }
}