Solved

Using a do-while loop and function  calls

Posted on 2000-03-14
2
1,789 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

IT, Stop Being Called Into Every Meeting

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

Join & Write a Comment

Article by: SunnyDark
This article's goal is to present you with an easy to use XML wrapper for C++ and also present some interesting techniques that you might use with MS C++. The reason I built this class is to ease the pain of using XML files with C++, since there is…
Introduction This article is a continuation of the C/C++ Visual Studio Express debugger series. Part 1 provided a quick start guide in using the debugger. Part 2 focused on additional topics in breakpoints. As your assignments become a little more …
The viewer will learn how to clear a vector as well as how to detect empty vectors in C++.
The viewer will be introduced to the technique of using vectors in C++. The video will cover how to define a vector, store values in the vector and retrieve data from the values stored in the vector.

708 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

Need Help in Real-Time?

Connect with top rated Experts

14 Experts available now in Live!

Get 1:1 Help Now