Solved

Using a do-while loop and function  calls

Posted on 2000-03-14
2
1,793 Views
Last Modified: 2010-08-05
main()
{
    int a = 0, b = 1, c = 0               /* initialize the series to 0, 1 */
    int sum();                              /* declare function to calc sums */

    printf("fibonacci\n");
    printf("%5d \n", a);
    printf("%5d \n", b);

    do
    {

     c = sum(a, b);
     printf("%5d\n", c);
     a = b;
     b = c;

     }
     
     while (c < 10000);

}

int sum (x, y) /* the parameters x and y receive the values of */
int x, y;          /* the two arguments passed by sum(a, b) in main() */

{

    return x + y;

}


Question: I need to use a subtract function to calculate and display the differences between the suceeding numbers in the fibonacci series.
I need to calculate and display thr quotients of the succeding fibonacci series in a third data column, right next to the differences.  For the divisions I need a division function named divide to perform this calculation.  To preserve the decimal accuracy of thequotients I will need to declare and use a float type function with two arguments  
0
Comment
Question by:mvjohn
2 Comments
 
LVL 7

Expert Comment

by:KangaRoo
ID: 2615611
When the new number is calculated, the old number remains in b, so the difference could be obtained from c - b, which is probably equal to a, provided that sum(a,b) calculates a + b ... The quotient is double(c) / b. I don't see why you would need functions for these simple expressions
0
 
LVL 10

Accepted Solution

by:
RONSLOW earned 10 total points
ID: 2619912
KangaRoo: Because it is a school/college/uni assignment? :-)

mvjohn: for accuracy, use a double, not a float type.  float types are not much use (except to save memeory when you are using a LOT of them).

Also, you are using yucky old-style C declarations.  This is bad programming practice.  You should declare your sum function as:

  int sum (int x, int y);

and define it as:

  int sum (int x, int y) {
    return x+y;
  }

I think, without giving too much away, your subtract and divide functions would be

  int subtract (int x, int y) {
    return x-y;
  }

  double divide (double x, double y) {
    return x/y;
  }

then you'd change
  printf("%5d\n", c);
into
  printf("%5d %5d %8.5f\n", c, subtract(c,b), divide(c,b));

PS: you'll probaby want to put some error checking in the divide routine to avoid division by zero.


0

Featured Post

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Go is an acronym of golang, is a programming language developed Google in 2007. Go is a new language that is mostly in the C family, with significant input from Pascal/Modula/Oberon family. Hence Go arisen as low-level language with fast compilation…
Basic understanding on "OO- Object Orientation" is needed for designing a logical solution to solve a problem. Basic OOAD is a prerequisite for a coder to ensure that they follow the basic design of OO. This would help developers to understand the b…
The goal of the video will be to teach the user the difference and consequence of passing data by value vs passing data by reference in C++. An example of passing data by value as well as an example of passing data by reference will be be given. Bot…
The viewer will learn how to user default arguments when defining functions. This method of defining functions will be contrasted with the non-default-argument of defining functions.

821 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question