Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • World
  • Users
  • Groups
Skins
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Code Project
  1. Home
  2. General Programming
  3. C#
  4. How do I generate a number divisable by 5, and check it?

How do I generate a number divisable by 5, and check it?

Scheduled Pinned Locked Moved C#
questionlounge
79 Posts 34 Posters 0 Views 1 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • R riced

    Look at what I said - add 5 or 10. If a number is divisible by 5 it must end in 5 or 0 - that's primary school arithmetic. If you don't believe me write out the 5 times table for the numbers 1 to 20.

    Regards David R --------------------------------------------------------------- "Every program eventually becomes rococo, and then rubble." - Alan Perlis The only valid measurement of code quality: WTFs/minute.

    K Offline
    K Offline
    KP Lee
    wrote on last edited by
    #57

    You can't just add 5. Say your result is 135978653, adding 5, the last digit is 8, not divisable by 5

    R 1 Reply Last reply
    0
    • K KP Lee

      Actually 0 is divisable by any number. :laugh:

      D Offline
      D Offline
      David1987
      wrote on last edited by
      #58

      Good luck dividing zero by zero.

      K 2 Replies Last reply
      0
      • S stephen darling

        Hi. First, how would I create a random number, and then add the last digit, so that it is divisable by 5? the number should always be 5 digits long. Second, how do I check it, I think I need to do something like...

        if (int x MOD 5 ==0)

        Or something like that. The first step is the most important though. Thank you, Steve

        K Offline
        K Offline
        KP Lee
        wrote on last edited by
        #59

        You are getting all sorts of advice. Multiplying by 10 can result in overflow. The easiest is: num -= num%5; IE subtract the remainder if you divided by five from the result. Another way: num = (num/5) * 5; That will NEVER cause an overflow in most languages. If you are using vb.net, besides the syntax replace "/" with "\".

        1 Reply Last reply
        0
        • K KP Lee

          You can't just add 5. Say your result is 135978653, adding 5, the last digit is 8, not divisable by 5

          R Offline
          R Offline
          riced
          wrote on last edited by
          #60

          I did say multiply by 10 then add 5. I also said you could add 5 or 10 - but adding 10 is silly. The multiplication automatically makes it divisible by 5. :laugh:

          Regards David R --------------------------------------------------------------- "Every program eventually becomes rococo, and then rubble." - Alan Perlis The only valid measurement of code quality: WTFs/minute.

          K 1 Reply Last reply
          0
          • V Vite Falcon

            x = generate random number between 10000 and 99995 remainder to be added = 5 - x MOD 5 Therefore, the resultant random number should be x + 5 - x MOD 5 Here's a sample code: http://ideone.com/LxgrC[^]

            a.k.a. Vite Phoenix and Vite Zeus... Proud member and co-founder of OlympianZ

            M Offline
            M Offline
            Michael A Cochran
            wrote on last edited by
            #61

            Why didn't I think of that? :rolleyes: Too much business programming, I guess. We don't use modulus in business programming much - at least I haven't had the need. Correct, of course. Much more elegant. If Stephen is still listening, in C# it becomes;

            // To generate as random numbers as possible, this variable must only
            // be initialized once and then reused as much as possible.
            Random rand = new Random();

            /// <summary>
            /// Generates a random number between 0 and 99995 that is always divisible by 5.
            /// </summary>
            /// <returns>Returns a random integer up to 5 digits long that is evenly divisible by 5.</returns>
            private int GetDivBy5()
            {
            // Get a random number between 0 and 99999.
            int divBy5 = rand.Next(0, 99999);
            // Subtract the remainder of (n/5) to make n divisible by 5.
            return divBy5 - (divBy5 % 5);
            }

            private void button1_Click(object sender, EventArgs e)
            {
            this.textBox1.Text = this.GetDivBy5().ToString("00000");

            }

            1 Reply Last reply
            0
            • R riced

              I did say multiply by 10 then add 5. I also said you could add 5 or 10 - but adding 10 is silly. The multiplication automatically makes it divisible by 5. :laugh:

              Regards David R --------------------------------------------------------------- "Every program eventually becomes rococo, and then rubble." - Alan Perlis The only valid measurement of code quality: WTFs/minute.

              K Offline
              K Offline
              KP Lee
              wrote on last edited by
              #62

              Yes, I did read that, I was tweaking. Seriously, multiplying exposes an overflow possiblity. And why 10? num = (num/5)*5; does the trick num -= num%5; also assures overflow won't occur even if you are within 5 of overflow in either positive or negative direction.

              R 1 Reply Last reply
              0
              • R riced

                Generate a four digit random number, multiply it by 10, add 5 (or 10). The result will be divisible by 5.

                Regards David R --------------------------------------------------------------- "Every program eventually becomes rococo, and then rubble." - Alan Perlis The only valid measurement of code quality: WTFs/minute.

                M Offline
                M Offline
                mooman27
                wrote on last edited by
                #63

                This solution is not correct - it exhibits a possible overflow error into 6 digits. Consider: 4 Random digits all come out as 9 (multiply by 10 = 99990), then add 10 you get 100000 which does not meet the requirements... The correct solution is: Generate a four digit random number Multiply it by 10 (to shift into correct position) Then randomly choose to make the last digit a 5 or a 0 (adding 10 is the incorrect step) The result is divisible by 5. Regards David.

                R 1 Reply Last reply
                0
                • D David1987

                  x is not a natural number there.

                  B Offline
                  B Offline
                  BobJanova
                  wrote on last edited by
                  #64

                  And your point is? (Neither is 0, right?) Both are representable in the number system, and both divide by 5 in any reasonable definition.

                  1 Reply Last reply
                  0
                  • D David1987

                    Good luck dividing zero by zero.

                    K Offline
                    K Offline
                    KP Lee
                    wrote on last edited by
                    #65

                    I KNEW there was a reason why I liked num -= num%5; better! :) How often have you seen a sizable random number generator produce 0 as an answer? (OK, you can easily set your random number limit so *10 will never overflow.) The original request is divisable by 5 and only affecting the last digit, not the whole number. Lets see: convert the int to a string, take a substring 1 less than the length, add "5" to the string and then convert back to int. There's quite a few ways to get this to work, multiplying by 10 and adding 5 will ONLY work correctly when the random number IS zero. Exactly where did I say to divide by zero? If num is zero, num=(num/5)*5 will produce zero. The highest numbers in int16, int, and int64 all end in decimal 7 and this process will work in all languages, the lowest number ends in 8. That will work in reasonable languages, VB.NET will blow up with an overflow. (In that language use num=(num\5)*5) (Actually VB is a reasonable language, you just have to know the gotchas like 5/3 is 2, not 1. I spent a little time swearing at its math until I found "\". I haven't found a use for round-up but if I did, VB would actually work quite a bit better than most languages for that.) Also good luck executing 5/0! (Or ANY other number by 0)

                    1 Reply Last reply
                    0
                    • D David1987

                      Good luck dividing zero by zero.

                      K Offline
                      K Offline
                      KP Lee
                      wrote on last edited by
                      #66

                      Sorry, different thread. I did say any number and you are totally right and the rest of my rant was uncalled for.

                      1 Reply Last reply
                      0
                      • V Vite Falcon

                        x = generate random number between 10000 and 99995 remainder to be added = 5 - x MOD 5 Therefore, the resultant random number should be x + 5 - x MOD 5 Here's a sample code: http://ideone.com/LxgrC[^]

                        a.k.a. Vite Phoenix and Vite Zeus... Proud member and co-founder of OlympianZ

                        F Offline
                        F Offline
                        fuximus
                        wrote on last edited by
                        #67

                        nice, the shortest and the best so far

                        1 Reply Last reply
                        0
                        • S stephen darling

                          Hi. First, how would I create a random number, and then add the last digit, so that it is divisable by 5? the number should always be 5 digits long. Second, how do I check it, I think I need to do something like...

                          if (int x MOD 5 ==0)

                          Or something like that. The first step is the most important though. Thank you, Steve

                          V Offline
                          V Offline
                          vaibhav92
                          wrote on last edited by
                          #68

                          I guess a simple expression like

                          int random= (rand()%18000)*5 + 10000

                          should do the trick where rand() is a function that returns any positive random number for C# it can be replaced with

                          int random= (new Random().Next()%18000)*5 + 10000

                          1 Reply Last reply
                          0
                          • S stephen darling

                            Hi. First, how would I create a random number, and then add the last digit, so that it is divisable by 5? the number should always be 5 digits long. Second, how do I check it, I think I need to do something like...

                            if (int x MOD 5 ==0)

                            Or something like that. The first step is the most important though. Thank you, Steve

                            L Offline
                            L Offline
                            lukeer
                            wrote on last edited by
                            #69

                            The solution I found most elegant had already been posted by David1984 but is deleted. So I'm going to post it now: You want a number X that can be divided by 5. Any number Y can be multiplied by 5. The result X is divisible by definition (and by 5). You want X to have 5 digits. 5-digit-numbers range from 10000 to 99999. Divide both by 5 and throw away the result's decimal places to get the limits for Y (2000 to 19999). Supposed you already have an instance of Random obeying the tips on its use, you get X by using this code (X changed to a meaningful name)

                            int randomDivisibleByFive = random.Next(2000, 19999) * 5;

                            Ciao, luker

                            1 Reply Last reply
                            0
                            • M Michael A Cochran

                              // To generate as random numbers as possible, this variable must only
                              // be initialized once and then reused as much as possible.
                              Random rand = new Random();
                              /// <summary>
                              /// Generates a random 5 digit number that is always divisible by 5.
                              /// </summary>
                              /// <returns>Returns a random integer 5 digits long that is evenly divisible by 5.</returns>
                              private int GetDivBy5()
                              {

                              // rnd.Next(minValue, maxValue) returns a random between minValue
                              // and maxValue, inclusive. Use min/max values of 1000 and 9999 to
                              // yield a random 4 digit number between 1000 and 9999 then multiply
                              // by 10 to get a 5 digit number.  This number will always be
                              // divisible by 5 but will always end in 0.
                              int divBy5 = rand.Next(1000, 9999) \* 10;
                              
                              // To get more random and double the possible result set, randomly
                              // add on 5.  This will yield the total possible set of integers
                              // between 10000 and 99995 that are divisible by 5.
                              if (rand.NextDouble() < 0.5)
                                  return divBy5;
                              else
                                  return divBy5 + 5;
                              

                              }

                              Stephen, you mention you are a coding noobie. So, a short word about random number generators - they're not really very random.
                              All they do is take a seed (beginning) value and run it through a mathmatical algorithm that generates a new number. If you use the same seed value every time, you will get the same "random" number every time. Most random number generators can either self-seed - generally using the current clock value - or you can pass them a seed value when you initialize them. This is why you only want to initialize your random number generator once and reuse it over and over. Once you get past that, the rest is pretty easy. Just use the math several others have already provided. See the comments in the code... <edit> Um, just looked at the thread in the other forum where you defined your requirements a little better. It seems you would like to include 0-9999 in your result set too. You can do this easily enough by changing the min value passed to rand.Next(minValue, maxValue) to 0 instead of 1000. This last bit, is a bit tricky in that in programming terms "00005" is actually not a number but is really a string. To get the leading zeros, you need to convert your final value to a string and use a formatting mask to append the leading zeros. This also assumes "00000" is valid. If it's not, test for it with an "if" and call GetDivBy5 again. So, to get a string with leading ze

                              J Offline
                              J Offline
                              jsc42
                              wrote on last edited by
                              #70

                              http://www.xkcd.com/221/[^]

                              1 Reply Last reply
                              0
                              • K KP Lee

                                Yes, I did read that, I was tweaking. Seriously, multiplying exposes an overflow possiblity. And why 10? num = (num/5)*5; does the trick num -= num%5; also assures overflow won't occur even if you are within 5 of overflow in either positive or negative direction.

                                R Offline
                                R Offline
                                riced
                                wrote on last edited by
                                #71

                                Did you read the bit that says generate a four digit number? That won't generate an overflow. :) The OP wanted 5 digit numbers.

                                Regards David R --------------------------------------------------------------- "Every program eventually becomes rococo, and then rubble." - Alan Perlis The only valid measurement of code quality: WTFs/minute.

                                K 1 Reply Last reply
                                0
                                • M mooman27

                                  This solution is not correct - it exhibits a possible overflow error into 6 digits. Consider: 4 Random digits all come out as 9 (multiply by 10 = 99990), then add 10 you get 100000 which does not meet the requirements... The correct solution is: Generate a four digit random number Multiply it by 10 (to shift into correct position) Then randomly choose to make the last digit a 5 or a 0 (adding 10 is the incorrect step) The result is divisible by 5. Regards David.

                                  R Offline
                                  R Offline
                                  riced
                                  wrote on last edited by
                                  #72

                                  See my correction - you don't need to add 10 at all (you can add 5 without fear). That was a silly on my part. :)

                                  Regards David R --------------------------------------------------------------- "Every program eventually becomes rococo, and then rubble." - Alan Perlis The only valid measurement of code quality: WTFs/minute.

                                  1 Reply Last reply
                                  0
                                  • R riced

                                    Did you read the bit that says generate a four digit number? That won't generate an overflow. :) The OP wanted 5 digit numbers.

                                    Regards David R --------------------------------------------------------------- "Every program eventually becomes rococo, and then rubble." - Alan Perlis The only valid measurement of code quality: WTFs/minute.

                                    K Offline
                                    K Offline
                                    KP Lee
                                    wrote on last edited by
                                    #73

                                    riced wrote:

                                    Did you read the bit that says generate a four digit number? That won't generate an overflow. :)
                                    The OP wanted 5 digit numbers.

                                    1. No, I ignored the 5 digit requirement on first reading. My bad. 2. No, I didn't see "generate a four digit number" in the original post and on re-reading still don't see it. Must be written in invisible ink. 3. You are right, no overflow. (Really dumb to use int16 on a 5 digit number because of good chance for overflow.) I'm going to assume he intended to generate a 5 digit number because he's asking how to modify the last digit. It would be really dumb to ask how to modify the last digit to be divisable by 5 if you start out with 4 digits and want 5. A lot of random number generators produce a number between 0 and 1. You can't get a negative number from that and real numbers have at best 6 digits of accuracy so keeping it down to 5 places makes sense. If you multiply the real number by 100K it is possible to get a number below 10K. So, set your int field to 0, while it is 0 set it to the random number times 100K. (Hopefully not an infinite loop :) ) While it is less than 10K multiply by 5. Then subtract the remainder of 5.

                                    R 1 Reply Last reply
                                    0
                                    • K KP Lee

                                      riced wrote:

                                      Did you read the bit that says generate a four digit number? That won't generate an overflow. :)
                                      The OP wanted 5 digit numbers.

                                      1. No, I ignored the 5 digit requirement on first reading. My bad. 2. No, I didn't see "generate a four digit number" in the original post and on re-reading still don't see it. Must be written in invisible ink. 3. You are right, no overflow. (Really dumb to use int16 on a 5 digit number because of good chance for overflow.) I'm going to assume he intended to generate a 5 digit number because he's asking how to modify the last digit. It would be really dumb to ask how to modify the last digit to be divisable by 5 if you start out with 4 digits and want 5. A lot of random number generators produce a number between 0 and 1. You can't get a negative number from that and real numbers have at best 6 digits of accuracy so keeping it down to 5 places makes sense. If you multiply the real number by 100K it is possible to get a number below 10K. So, set your int field to 0, while it is 0 set it to the random number times 100K. (Hopefully not an infinite loop :) ) While it is less than 10K multiply by 5. Then subtract the remainder of 5.

                                      R Offline
                                      R Offline
                                      riced
                                      wrote on last edited by
                                      #74

                                      Here's my original post: (the add 10 is redundant - me being silly)

                                      Generate a four digit random number,
                                      multiply it by 10,
                                      add 5 (or 10).
                                      The result will be divisible by 5.

                                      The adding 5 could be done at random. The Random class in C# allows you to get next integer in a range e.g. x = Random.Next(0, 10000) gets you a number on range 0 to 9999 (the second parameter is the exclusive upper limit). So no need to mess about multiplying by 100k. He could use Random.Next(1000, 10000) if he actually requires, or just use String formatting if it's just to be displayed.

                                      Regards David R --------------------------------------------------------------- "Every program eventually becomes rococo, and then rubble." - Alan Perlis The only valid measurement of code quality: WTFs/minute.

                                      1 Reply Last reply
                                      0
                                      • S stephen darling

                                        Kenneth Kasajian wrote:

                                        Is this discussion really taking place? What is this, 3rd grade?

                                        What is everones problem? I asked how to solve a basic math based problem PROGMATICALLY as I am a beginner when it comes to c#, and I am wishing I never bothered asking! Although, there are a number of people who have offered working solutions. Why must people post such a responce as yours? Did your post really help in anyway? Regards, Stephen

                                        K Offline
                                        K Offline
                                        Kenneth Kasajian
                                        wrote on last edited by
                                        #75

                                        Let me be clear. I don't have any problem with people asking very basic programming questions. In fact, I encourage it. I don't expect people to know everything about programming. I was commenting on this discussions of what numbers are divisible by 5, as in: "However, I was under the impression I could generate numbers that would be divisible by 5, but not end in 5? Is this wrong?" You're kidding me right? You don't know that the numbers 10 and 20 are divisible by 5? Clearly they don't end in 5. My comment was no to the programming question.

                                        ken@kasajian.com / www.kasajian.com

                                        S 1 Reply Last reply
                                        0
                                        • K Kenneth Kasajian

                                          Let me be clear. I don't have any problem with people asking very basic programming questions. In fact, I encourage it. I don't expect people to know everything about programming. I was commenting on this discussions of what numbers are divisible by 5, as in: "However, I was under the impression I could generate numbers that would be divisible by 5, but not end in 5? Is this wrong?" You're kidding me right? You don't know that the numbers 10 and 20 are divisible by 5? Clearly they don't end in 5. My comment was no to the programming question.

                                          ken@kasajian.com / www.kasajian.com

                                          S Offline
                                          S Offline
                                          stephen darling
                                          wrote on last edited by
                                          #76

                                          Kenneth Kasajian wrote:

                                          You're kidding me right?

                                          Are you? This thread was cleared up a while ago, and I am not going to explain myself yet again :) Regards!

                                          K 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Categories
                                          • Recent
                                          • Tags
                                          • Popular
                                          • World
                                          • Users
                                          • Groups