Jump to content
xisto Community
Sign in to follow this  
derouge

A Small Project: Splitting An Integer Into Digits

Recommended Posts

I need to know how to "split" a number up into seperae numbers, using VB. For example, "54321". I need to split that into 5 seperate numbers - "5," "4," "3," "2," "1," and assign them to a variable, if possible. This next part isn't important, but if you're curious why I need to know ...Eventually what I need to do is split the number into these individual parts and add them together. With that new number I need to again split it and take the last number subtracted from 10. That new number will then be placed at the end of the beginning number.Example:5+4+3+2+1 = 1515 = 1 & 5, take the last number ..10-5 = 5New number = "543215"The thing is I have no clue how to split this number into the seperate parts. Once I get past that I'm 99% sure I can wrap up. Anyone able to help? If so, Thanks! :D

Edited by miCRoSCoPiC^eaRthLinG (see edit history)

Share this post


Link to post
Share on other sites

That should be fairly easy with the String manipulation routines that accompany VB. There are infact two methods you can follow.

 

Method 1:

????[/tab]To start with, you can simple convert the number into a string - and then use the substring function to find out each character. To achieve this we'll have to find the length of the string - which is 5, in your example above - and then iterate through each position of the string, picking up individual characters as we go.

'Say my number is stored in a variable called NumDim Num As Integer = 54321'First I declare two variables - actually one Array to hold each character'We just assing a random number of elements to the array - having 32'will help us deal with numbers as long as 32 digits longDim Digits (32) As Integer'And one variable to hold the length of the stringDim Length As Integer'I convert it to a String firstDim NumString As String = CType ( Num, String )'This NULL-Check is implemented so that if you use an empty string here, the code'won't crash when it comes to checking for the substring - but instead would'gracefully skip this part altogetherIf NumString <> "" Then      'Now I find the length of the string -      Length = NumString.Length    'Iterate through the string, picking up each character    For Index As Integer = 0 To Length - 1        Digits ( Index ) = CType ( NumString.SubString ( Index, 1 ), Integer )    NextEnd If

That's it - the above approach will give you an array called Digits() whose positions indexed by 0 through Length - 1 will contain the individual digits of your number.

 

[hr=noshade][/hr]

Method 2:

????The second method essentially involves the same principle as above - but computationally is a little faster - as the algorithm is based on numerical computations. A few words on the algorithm first.

 

????Take for example, your own number, 54321 - can you think of a concrete method of stripping the number off the first digit "5" - leaving behind only "4321" ??

What would give you 5 as a result, if you divide 54321 by it ? You'd instantly arrive on the figure 10,000.

So: 54321 / 10000 = 5

This is all fine - you've got your first digit. But then how do you get the rest of the number together ? Arithmatically, if you divide 54321 by 10000 - we'd have a remainder of 4321 - that's exactly what we need. So how do you find the remainder. Here's where an arithmatic operator called Mod comes into play. It's known as Mod in terms of Visual Basic - and mostly represented as a % symbol in languages like C/C++, Java etc.

So: 54321 Mod 10000 = 4321

 

There - we have our first digit extracted, leaving behind the last four. Now if you repeat the above steps, except that you divide and do the Mod with 1,000 instead of 10,000 - you'd yet extract one more digit leaving behind the last 3. Next you repeat the steps again with 100 and then with 10 - and you'd have all your digits separated out.

 

How do we implement this ? Here's the code:

'Say Num contains the numberDim Num As Integer = 54321'Once again - we find the length of the number - which gives us the number of'digits in it, and then we declare an array based on that numberDim Length As IntegerIf Str ( Num ) <> "" Then    Length = Str ( Num ).LengthEnd If'Next we declare two variables and an arrayDim Divisor As Integer = 10 ^ ( Length - 1 )Dim Index As Integer = 0Dim Digits ( Length - 1 ) As Integer'Here we start the LoopWhile ( Divisor > 0 )        'Extract the first digit    Digits ( Index ) = Int ( Num / Divisor )        'Extract remainder number - and store it back in Num    Num = Num Mod Divisor    'Decrease Divisor's value by 1/10th units    Divisor /= 10    'Increment Index    Index += 1End While

Even in this case, your array Digits() will contain the extracted digits starting from position 0 through Length - 1.

 

[tab]Try out both and let me know - both should work just fine, giving your the same output. Personally, I find the second method more ELEGANT. The first one is a little blunt - doing things by brute force, although is much easier to understand. However, as I mentioned earlier, the second one computes way faster.

 

All the best :D

m^e

Share this post


Link to post
Share on other sites

Well it would be relevant if you posted which language you wanted this solution for. I think converting a number into string and then converting into numbers again is an easy solution. In C++ probably the shift operatros would do the trick.

Share this post


Link to post
Share on other sites

Oh yeah - that reminds me, since you made the post in VB.NET forum - the solution provided was in that same language too.

 

Also hatim - if you notice the solution I provided in Method 1 does exactly the same - conversion to string, extraction and then back to integer - and the second method entirely eliminates the need to do that, thus making the algorithm far more efficient.

Share this post


Link to post
Share on other sites

Awesome. Glad that helped :D That second method was a chance discovery while I was experimenting with coding a bunch of numerical manipulations quite sometime back - in relation to this cryptographic routine that I was trying to come up with.

Share this post


Link to post
Share on other sites
split and suming numbers in javaA Small Project: Splitting An Integer Into Digits

how do I split up a four digit number in java and sum up the individual numbers to get their sum?

-reply by willie

 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

×
×
  • Create New...

Important Information

Terms of Use | Privacy Policy | Guidelines | We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.