Solved

Algorithm

Posted on 1998-06-08
3
356 Views
Last Modified: 2010-04-01
What is the best algorithm to check a number is in which particular range of:
0 to 9
10 to 99
100 to 999
1000 to 9999
10000 to 99999
...rate at exponential of 10

E.g X = 555 is in the range of 100 - 999

I use a if-else-then to do the checking but its looks terribly ugly.

Any advice?
0
Comment
Question by:engllf
3 Comments
 
LVL 23

Accepted Solution

by:
chensu earned 50 total points
ID: 1165459
Which is the best depends on the actual requirements. Here is an alternative. But you still need to check the value of n. You may use n as an index of an array.


#include <math.h>

.

if (X >= 0)
{
    unsigned int n = X == 0 ? 0 : log10((double)X);
    // 0 to 9, n = 0
    // 10 to 99, n = 1
    // 100 to 999, n = 2
    // 1000 to 9999, n = 3
    // ...
}
else
{
   ...
}

0
 
LVL 4

Expert Comment

by:sganta
ID: 1165460


      I have simple and beautiful algorithm and solution for your problem.

      ALGORITHM
      1. Read the number into "n";
      2. Store this number n as a string into test
          i.e., test = string(n);
      3. Get the length of the string into length
          length = string_length(n);
      4. Now
          Range_From = power(10,length-1)
          Range_To     = power(10,length)-1
      5. End of the algorithm

      /* Here the solution in C++ */

      #include <iostream.h>
      #include <string.h>
      #include <math.h>

      void main(void)
      {
         int n,len,ifrom,ito;
         char *test;

         cout << "Enter a number ";
         cin >>n;

         test = itoa(n); /* Converts integer to Ascii */
         len = strlen(test);
         ifrom = pow(10,len-1);
         ito = pow(10,len)-1;
         cout << "The number "<<n<<" is in the range from "<<ifrom<<" to "<<ito<<endl;
      }

      This  algorithm is tested and it works fine. If you are interested with my answer
      Please reject the above answer and accept my answer.
      Thank you.
      JESUS LOVES YOU - sganta





0
 
LVL 22

Expert Comment

by:nietod
ID: 1165461
engllf, just so you know, while sganta's solution is pretty short and very slick, it is not very efficient.  If you are concerned about speed, you'll want to use chensu's solution.  But if you aren't concerned about speed, sganta's solution is pretty clear and simple.
0

Featured Post

Networking for the Cloud Era

Join Microsoft and Riverbed for a discussion and demonstration of enhancements to SteelConnect:
-One-click orchestration and cloud connectivity in Azure environments
-Tight integration of SD-WAN and WAN optimization capabilities
-Scalability and resiliency equal to a data center

Question has a verified solution.

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

Introduction This article is the first in a series of articles about the C/C++ Visual Studio Express debugger.  It provides a quick start guide in using the debugger. Part 2 focuses on additional topics in breakpoints.  Lastly, Part 3 focuses on th…
This article will show you some of the more useful Standard Template Library (STL) algorithms through the use of working examples.  You will learn about how these algorithms fit into the STL architecture, how they work with STL containers, and why t…
The goal of the video will be to teach the user the concept of local variables and scope. An example of a locally defined variable will be given as well as an explanation of what scope is in C++. The local variable and concept of scope will be relat…
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…

839 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