How to add two very large numbers irrespective of their size in Java without using BigInteger data type?










0















I need to add two very large numbers without using BigInteger. I am taking two string parameters but the below code only works with strings of equal length otherwise it throws IndexOutOfBoundsException. How can I fix that by adding big numbers irrespective of their length?



public static String add(String a, String b) 
int carry = 0;
String result = "";

for (int i = a.length() - 1; i >= 0; i--)
int digitA = a.charAt(i) - 48;
int digitB = b.charAt(i) - 48;

int resultingNumber = digitA + digitB + carry;
if (resultingNumber >= 10)
result = (resultingNumber % 10) + result;
carry = 1;
else
result = resultingNumber + result;
carry = 0;


if (carry > 0)
result = carry + result;

return result;










share|improve this question
























  • Insert leading zeros into the shorter String? Also, I'd use - '0'; instead of - 48;

    – Elliott Frisch
    Nov 13 '18 at 5:24












  • You could try aligning smaller one to the longer one by adding leading zeros.

    – sssemil
    Nov 13 '18 at 5:26






  • 1





    BigInteger is the tool for the job.

    – Raedwald
    Nov 13 '18 at 22:10















0















I need to add two very large numbers without using BigInteger. I am taking two string parameters but the below code only works with strings of equal length otherwise it throws IndexOutOfBoundsException. How can I fix that by adding big numbers irrespective of their length?



public static String add(String a, String b) 
int carry = 0;
String result = "";

for (int i = a.length() - 1; i >= 0; i--)
int digitA = a.charAt(i) - 48;
int digitB = b.charAt(i) - 48;

int resultingNumber = digitA + digitB + carry;
if (resultingNumber >= 10)
result = (resultingNumber % 10) + result;
carry = 1;
else
result = resultingNumber + result;
carry = 0;


if (carry > 0)
result = carry + result;

return result;










share|improve this question
























  • Insert leading zeros into the shorter String? Also, I'd use - '0'; instead of - 48;

    – Elliott Frisch
    Nov 13 '18 at 5:24












  • You could try aligning smaller one to the longer one by adding leading zeros.

    – sssemil
    Nov 13 '18 at 5:26






  • 1





    BigInteger is the tool for the job.

    – Raedwald
    Nov 13 '18 at 22:10













0












0








0








I need to add two very large numbers without using BigInteger. I am taking two string parameters but the below code only works with strings of equal length otherwise it throws IndexOutOfBoundsException. How can I fix that by adding big numbers irrespective of their length?



public static String add(String a, String b) 
int carry = 0;
String result = "";

for (int i = a.length() - 1; i >= 0; i--)
int digitA = a.charAt(i) - 48;
int digitB = b.charAt(i) - 48;

int resultingNumber = digitA + digitB + carry;
if (resultingNumber >= 10)
result = (resultingNumber % 10) + result;
carry = 1;
else
result = resultingNumber + result;
carry = 0;


if (carry > 0)
result = carry + result;

return result;










share|improve this question
















I need to add two very large numbers without using BigInteger. I am taking two string parameters but the below code only works with strings of equal length otherwise it throws IndexOutOfBoundsException. How can I fix that by adding big numbers irrespective of their length?



public static String add(String a, String b) 
int carry = 0;
String result = "";

for (int i = a.length() - 1; i >= 0; i--)
int digitA = a.charAt(i) - 48;
int digitB = b.charAt(i) - 48;

int resultingNumber = digitA + digitB + carry;
if (resultingNumber >= 10)
result = (resultingNumber % 10) + result;
carry = 1;
else
result = resultingNumber + result;
carry = 0;


if (carry > 0)
result = carry + result;

return result;







java biginteger






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 13 '18 at 6:03









Abhinav

394413




394413










asked Nov 13 '18 at 5:21









flashflash

274421




274421












  • Insert leading zeros into the shorter String? Also, I'd use - '0'; instead of - 48;

    – Elliott Frisch
    Nov 13 '18 at 5:24












  • You could try aligning smaller one to the longer one by adding leading zeros.

    – sssemil
    Nov 13 '18 at 5:26






  • 1





    BigInteger is the tool for the job.

    – Raedwald
    Nov 13 '18 at 22:10

















  • Insert leading zeros into the shorter String? Also, I'd use - '0'; instead of - 48;

    – Elliott Frisch
    Nov 13 '18 at 5:24












  • You could try aligning smaller one to the longer one by adding leading zeros.

    – sssemil
    Nov 13 '18 at 5:26






  • 1





    BigInteger is the tool for the job.

    – Raedwald
    Nov 13 '18 at 22:10
















Insert leading zeros into the shorter String? Also, I'd use - '0'; instead of - 48;

– Elliott Frisch
Nov 13 '18 at 5:24






Insert leading zeros into the shorter String? Also, I'd use - '0'; instead of - 48;

– Elliott Frisch
Nov 13 '18 at 5:24














You could try aligning smaller one to the longer one by adding leading zeros.

– sssemil
Nov 13 '18 at 5:26





You could try aligning smaller one to the longer one by adding leading zeros.

– sssemil
Nov 13 '18 at 5:26




1




1





BigInteger is the tool for the job.

– Raedwald
Nov 13 '18 at 22:10





BigInteger is the tool for the job.

– Raedwald
Nov 13 '18 at 22:10












3 Answers
3






active

oldest

votes


















2














You can prepend the shorter string with zeros to make it match the length of the other number:



private static String leftPad(String s, int length) 
if (s.length() >= length)
return s;

StringBuilder sb = new StringBuilder();
for (int i = 0; i < length - s.length(); i++)
sb.append("0");

return sb.toString() + s;


public static String add(String originalA, String originalB) {

int maxLength = Math.max(originalA.length(), originalB.length());
String a = leftPad(originalA, maxLength);
String b = leftPad(originalB, maxLength);

... rest of your method





share|improve this answer






























    3














    There is no need to pad any of the parameters with zeroes. Also, for better performance, don't use String + String.



    Create a char for the result. Since the result can be 1 longer than the longest input, create it at that size.



    Then iterate from end of input strings, setting each character in the result.



    Then eliminate any leading zeroes, resulting from inputs not overflowing or from inputs having leading zeroes.



    Finally, create a String from the char using the String(char value, int offset, int count) constructor.



    Like this:



    public static String add(String a, String b) 
    int i = a.length();
    int j = b.length();
    int k = Math.max(i, j) + 1; // room for carryover
    char c = new char[k];
    for (int digit = 0; k > 0; digit /= 10)
    if (i > 0)
    digit += a.charAt(--i) - '0';
    if (j > 0)
    digit += b.charAt(--j) - '0';
    c[--k] = (char) ('0' + digit % 10);

    for (k = 0; k < c.length - 1 && c[k] == '0'; k++) /*Skip leading zeroes*/
    return new String(c, k, c.length - k);



    Test



    public static void main(String args) 
    test("1234", "2345"); // test equal-sized inputs, no carry-over
    test("12345", "12345"); // test equal-sized inputs, with carry-over
    test("54321", "54321"); // test equal-sized inputs, longer result
    test("99999", "99999"); // test max result
    test("5", "1234"); // test odd-sized inputs, no carry-over
    test("5", "12345"); // test odd-sized inputs, with carry-over
    test("1", "99999"); // test with a carry-over to longer result
    test("001", "00002"); // test leading zeroes in input are eliminated
    test("000", "00000"); // test leading zero removal leaves 1 zero

    public static void test(String a, String b)
    // Test add is commutative, i.e. a+b = b+a
    System.out.printf("%s + %s = %s = %s%n", a, b, add(a, b), add(b, a));



    Output



    1234 + 2345 = 3579 = 3579
    12345 + 12345 = 24690 = 24690
    54321 + 54321 = 108642 = 108642
    99999 + 99999 = 199998 = 199998
    5 + 1234 = 1239 = 1239
    5 + 12345 = 12350 = 12350
    1 + 99999 = 100000 = 100000
    001 + 00002 = 3 = 3
    000 + 00000 = 0 = 0





    share|improve this answer
































      1














      You can left pad with zeroes the strings like this:



       int longestString = Math.max(a.length(), b.length());
      a = String.format("%1$" + longestString + "s", a).replace(' ', '0');
      b = String.format("%1$" + longestString + "s", b).replace(' ', '0');


      This will add leadings spaces to fill the "gap" and then replace them with zeroes.



      Class:



      public class Mission09 
      public static void main(String args)
      System.out.println(add("1", "1333"));


      public static String add(String a, String b)
      int carry = 0;
      String result = "";

      int longestString = Math.max(a.length(), b.length());

      a = String.format("%1$" + longestString + "s", a).replace(' ', '0');
      b = String.format("%1$" + longestString + "s", b).replace(' ', '0');


      for (int i = a.length() - 1; i >= 0; i--)
      int digitA = a.charAt(i) - 48;
      int digitB = b.charAt(i) - 48;

      int resultingNumber = digitA + digitB + carry;
      if (resultingNumber >= 10)
      result = (resultingNumber % 10) + result;
      carry = 1;
      else
      result = resultingNumber + result;
      carry = 0;


      if (carry > 0)
      result = carry + result;

      return result;





      I/O:



      System.out.println(add("1", "1333"));
      1334
      System.out.println(add("12222", "1333"));
      13555





      share|improve this answer






















        Your Answer






        StackExchange.ifUsing("editor", function ()
        StackExchange.using("externalEditor", function ()
        StackExchange.using("snippets", function ()
        StackExchange.snippets.init();
        );
        );
        , "code-snippets");

        StackExchange.ready(function()
        var channelOptions =
        tags: "".split(" "),
        id: "1"
        ;
        initTagRenderer("".split(" "), "".split(" "), channelOptions);

        StackExchange.using("externalEditor", function()
        // Have to fire editor after snippets, if snippets enabled
        if (StackExchange.settings.snippets.snippetsEnabled)
        StackExchange.using("snippets", function()
        createEditor();
        );

        else
        createEditor();

        );

        function createEditor()
        StackExchange.prepareEditor(
        heartbeatType: 'answer',
        autoActivateHeartbeat: false,
        convertImagesToLinks: true,
        noModals: true,
        showLowRepImageUploadWarning: true,
        reputationToPostImages: 10,
        bindNavPrevention: true,
        postfix: "",
        imageUploader:
        brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
        contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
        allowUrls: true
        ,
        onDemand: true,
        discardSelector: ".discard-answer"
        ,immediatelyShowMarkdownHelp:true
        );



        );













        draft saved

        draft discarded


















        StackExchange.ready(
        function ()
        StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53274293%2fhow-to-add-two-very-large-numbers-irrespective-of-their-size-in-java-without-usi%23new-answer', 'question_page');

        );

        Post as a guest















        Required, but never shown

























        3 Answers
        3






        active

        oldest

        votes








        3 Answers
        3






        active

        oldest

        votes









        active

        oldest

        votes






        active

        oldest

        votes









        2














        You can prepend the shorter string with zeros to make it match the length of the other number:



        private static String leftPad(String s, int length) 
        if (s.length() >= length)
        return s;

        StringBuilder sb = new StringBuilder();
        for (int i = 0; i < length - s.length(); i++)
        sb.append("0");

        return sb.toString() + s;


        public static String add(String originalA, String originalB) {

        int maxLength = Math.max(originalA.length(), originalB.length());
        String a = leftPad(originalA, maxLength);
        String b = leftPad(originalB, maxLength);

        ... rest of your method





        share|improve this answer



























          2














          You can prepend the shorter string with zeros to make it match the length of the other number:



          private static String leftPad(String s, int length) 
          if (s.length() >= length)
          return s;

          StringBuilder sb = new StringBuilder();
          for (int i = 0; i < length - s.length(); i++)
          sb.append("0");

          return sb.toString() + s;


          public static String add(String originalA, String originalB) {

          int maxLength = Math.max(originalA.length(), originalB.length());
          String a = leftPad(originalA, maxLength);
          String b = leftPad(originalB, maxLength);

          ... rest of your method





          share|improve this answer

























            2












            2








            2







            You can prepend the shorter string with zeros to make it match the length of the other number:



            private static String leftPad(String s, int length) 
            if (s.length() >= length)
            return s;

            StringBuilder sb = new StringBuilder();
            for (int i = 0; i < length - s.length(); i++)
            sb.append("0");

            return sb.toString() + s;


            public static String add(String originalA, String originalB) {

            int maxLength = Math.max(originalA.length(), originalB.length());
            String a = leftPad(originalA, maxLength);
            String b = leftPad(originalB, maxLength);

            ... rest of your method





            share|improve this answer













            You can prepend the shorter string with zeros to make it match the length of the other number:



            private static String leftPad(String s, int length) 
            if (s.length() >= length)
            return s;

            StringBuilder sb = new StringBuilder();
            for (int i = 0; i < length - s.length(); i++)
            sb.append("0");

            return sb.toString() + s;


            public static String add(String originalA, String originalB) {

            int maxLength = Math.max(originalA.length(), originalB.length());
            String a = leftPad(originalA, maxLength);
            String b = leftPad(originalB, maxLength);

            ... rest of your method






            share|improve this answer












            share|improve this answer



            share|improve this answer










            answered Nov 13 '18 at 5:32









            ernest_kernest_k

            23.7k42949




            23.7k42949























                3














                There is no need to pad any of the parameters with zeroes. Also, for better performance, don't use String + String.



                Create a char for the result. Since the result can be 1 longer than the longest input, create it at that size.



                Then iterate from end of input strings, setting each character in the result.



                Then eliminate any leading zeroes, resulting from inputs not overflowing or from inputs having leading zeroes.



                Finally, create a String from the char using the String(char value, int offset, int count) constructor.



                Like this:



                public static String add(String a, String b) 
                int i = a.length();
                int j = b.length();
                int k = Math.max(i, j) + 1; // room for carryover
                char c = new char[k];
                for (int digit = 0; k > 0; digit /= 10)
                if (i > 0)
                digit += a.charAt(--i) - '0';
                if (j > 0)
                digit += b.charAt(--j) - '0';
                c[--k] = (char) ('0' + digit % 10);

                for (k = 0; k < c.length - 1 && c[k] == '0'; k++) /*Skip leading zeroes*/
                return new String(c, k, c.length - k);



                Test



                public static void main(String args) 
                test("1234", "2345"); // test equal-sized inputs, no carry-over
                test("12345", "12345"); // test equal-sized inputs, with carry-over
                test("54321", "54321"); // test equal-sized inputs, longer result
                test("99999", "99999"); // test max result
                test("5", "1234"); // test odd-sized inputs, no carry-over
                test("5", "12345"); // test odd-sized inputs, with carry-over
                test("1", "99999"); // test with a carry-over to longer result
                test("001", "00002"); // test leading zeroes in input are eliminated
                test("000", "00000"); // test leading zero removal leaves 1 zero

                public static void test(String a, String b)
                // Test add is commutative, i.e. a+b = b+a
                System.out.printf("%s + %s = %s = %s%n", a, b, add(a, b), add(b, a));



                Output



                1234 + 2345 = 3579 = 3579
                12345 + 12345 = 24690 = 24690
                54321 + 54321 = 108642 = 108642
                99999 + 99999 = 199998 = 199998
                5 + 1234 = 1239 = 1239
                5 + 12345 = 12350 = 12350
                1 + 99999 = 100000 = 100000
                001 + 00002 = 3 = 3
                000 + 00000 = 0 = 0





                share|improve this answer





























                  3














                  There is no need to pad any of the parameters with zeroes. Also, for better performance, don't use String + String.



                  Create a char for the result. Since the result can be 1 longer than the longest input, create it at that size.



                  Then iterate from end of input strings, setting each character in the result.



                  Then eliminate any leading zeroes, resulting from inputs not overflowing or from inputs having leading zeroes.



                  Finally, create a String from the char using the String(char value, int offset, int count) constructor.



                  Like this:



                  public static String add(String a, String b) 
                  int i = a.length();
                  int j = b.length();
                  int k = Math.max(i, j) + 1; // room for carryover
                  char c = new char[k];
                  for (int digit = 0; k > 0; digit /= 10)
                  if (i > 0)
                  digit += a.charAt(--i) - '0';
                  if (j > 0)
                  digit += b.charAt(--j) - '0';
                  c[--k] = (char) ('0' + digit % 10);

                  for (k = 0; k < c.length - 1 && c[k] == '0'; k++) /*Skip leading zeroes*/
                  return new String(c, k, c.length - k);



                  Test



                  public static void main(String args) 
                  test("1234", "2345"); // test equal-sized inputs, no carry-over
                  test("12345", "12345"); // test equal-sized inputs, with carry-over
                  test("54321", "54321"); // test equal-sized inputs, longer result
                  test("99999", "99999"); // test max result
                  test("5", "1234"); // test odd-sized inputs, no carry-over
                  test("5", "12345"); // test odd-sized inputs, with carry-over
                  test("1", "99999"); // test with a carry-over to longer result
                  test("001", "00002"); // test leading zeroes in input are eliminated
                  test("000", "00000"); // test leading zero removal leaves 1 zero

                  public static void test(String a, String b)
                  // Test add is commutative, i.e. a+b = b+a
                  System.out.printf("%s + %s = %s = %s%n", a, b, add(a, b), add(b, a));



                  Output



                  1234 + 2345 = 3579 = 3579
                  12345 + 12345 = 24690 = 24690
                  54321 + 54321 = 108642 = 108642
                  99999 + 99999 = 199998 = 199998
                  5 + 1234 = 1239 = 1239
                  5 + 12345 = 12350 = 12350
                  1 + 99999 = 100000 = 100000
                  001 + 00002 = 3 = 3
                  000 + 00000 = 0 = 0





                  share|improve this answer



























                    3












                    3








                    3







                    There is no need to pad any of the parameters with zeroes. Also, for better performance, don't use String + String.



                    Create a char for the result. Since the result can be 1 longer than the longest input, create it at that size.



                    Then iterate from end of input strings, setting each character in the result.



                    Then eliminate any leading zeroes, resulting from inputs not overflowing or from inputs having leading zeroes.



                    Finally, create a String from the char using the String(char value, int offset, int count) constructor.



                    Like this:



                    public static String add(String a, String b) 
                    int i = a.length();
                    int j = b.length();
                    int k = Math.max(i, j) + 1; // room for carryover
                    char c = new char[k];
                    for (int digit = 0; k > 0; digit /= 10)
                    if (i > 0)
                    digit += a.charAt(--i) - '0';
                    if (j > 0)
                    digit += b.charAt(--j) - '0';
                    c[--k] = (char) ('0' + digit % 10);

                    for (k = 0; k < c.length - 1 && c[k] == '0'; k++) /*Skip leading zeroes*/
                    return new String(c, k, c.length - k);



                    Test



                    public static void main(String args) 
                    test("1234", "2345"); // test equal-sized inputs, no carry-over
                    test("12345", "12345"); // test equal-sized inputs, with carry-over
                    test("54321", "54321"); // test equal-sized inputs, longer result
                    test("99999", "99999"); // test max result
                    test("5", "1234"); // test odd-sized inputs, no carry-over
                    test("5", "12345"); // test odd-sized inputs, with carry-over
                    test("1", "99999"); // test with a carry-over to longer result
                    test("001", "00002"); // test leading zeroes in input are eliminated
                    test("000", "00000"); // test leading zero removal leaves 1 zero

                    public static void test(String a, String b)
                    // Test add is commutative, i.e. a+b = b+a
                    System.out.printf("%s + %s = %s = %s%n", a, b, add(a, b), add(b, a));



                    Output



                    1234 + 2345 = 3579 = 3579
                    12345 + 12345 = 24690 = 24690
                    54321 + 54321 = 108642 = 108642
                    99999 + 99999 = 199998 = 199998
                    5 + 1234 = 1239 = 1239
                    5 + 12345 = 12350 = 12350
                    1 + 99999 = 100000 = 100000
                    001 + 00002 = 3 = 3
                    000 + 00000 = 0 = 0





                    share|improve this answer















                    There is no need to pad any of the parameters with zeroes. Also, for better performance, don't use String + String.



                    Create a char for the result. Since the result can be 1 longer than the longest input, create it at that size.



                    Then iterate from end of input strings, setting each character in the result.



                    Then eliminate any leading zeroes, resulting from inputs not overflowing or from inputs having leading zeroes.



                    Finally, create a String from the char using the String(char value, int offset, int count) constructor.



                    Like this:



                    public static String add(String a, String b) 
                    int i = a.length();
                    int j = b.length();
                    int k = Math.max(i, j) + 1; // room for carryover
                    char c = new char[k];
                    for (int digit = 0; k > 0; digit /= 10)
                    if (i > 0)
                    digit += a.charAt(--i) - '0';
                    if (j > 0)
                    digit += b.charAt(--j) - '0';
                    c[--k] = (char) ('0' + digit % 10);

                    for (k = 0; k < c.length - 1 && c[k] == '0'; k++) /*Skip leading zeroes*/
                    return new String(c, k, c.length - k);



                    Test



                    public static void main(String args) 
                    test("1234", "2345"); // test equal-sized inputs, no carry-over
                    test("12345", "12345"); // test equal-sized inputs, with carry-over
                    test("54321", "54321"); // test equal-sized inputs, longer result
                    test("99999", "99999"); // test max result
                    test("5", "1234"); // test odd-sized inputs, no carry-over
                    test("5", "12345"); // test odd-sized inputs, with carry-over
                    test("1", "99999"); // test with a carry-over to longer result
                    test("001", "00002"); // test leading zeroes in input are eliminated
                    test("000", "00000"); // test leading zero removal leaves 1 zero

                    public static void test(String a, String b)
                    // Test add is commutative, i.e. a+b = b+a
                    System.out.printf("%s + %s = %s = %s%n", a, b, add(a, b), add(b, a));



                    Output



                    1234 + 2345 = 3579 = 3579
                    12345 + 12345 = 24690 = 24690
                    54321 + 54321 = 108642 = 108642
                    99999 + 99999 = 199998 = 199998
                    5 + 1234 = 1239 = 1239
                    5 + 12345 = 12350 = 12350
                    1 + 99999 = 100000 = 100000
                    001 + 00002 = 3 = 3
                    000 + 00000 = 0 = 0






                    share|improve this answer














                    share|improve this answer



                    share|improve this answer








                    edited Nov 13 '18 at 6:24

























                    answered Nov 13 '18 at 6:11









                    AndreasAndreas

                    78.5k464129




                    78.5k464129





















                        1














                        You can left pad with zeroes the strings like this:



                         int longestString = Math.max(a.length(), b.length());
                        a = String.format("%1$" + longestString + "s", a).replace(' ', '0');
                        b = String.format("%1$" + longestString + "s", b).replace(' ', '0');


                        This will add leadings spaces to fill the "gap" and then replace them with zeroes.



                        Class:



                        public class Mission09 
                        public static void main(String args)
                        System.out.println(add("1", "1333"));


                        public static String add(String a, String b)
                        int carry = 0;
                        String result = "";

                        int longestString = Math.max(a.length(), b.length());

                        a = String.format("%1$" + longestString + "s", a).replace(' ', '0');
                        b = String.format("%1$" + longestString + "s", b).replace(' ', '0');


                        for (int i = a.length() - 1; i >= 0; i--)
                        int digitA = a.charAt(i) - 48;
                        int digitB = b.charAt(i) - 48;

                        int resultingNumber = digitA + digitB + carry;
                        if (resultingNumber >= 10)
                        result = (resultingNumber % 10) + result;
                        carry = 1;
                        else
                        result = resultingNumber + result;
                        carry = 0;


                        if (carry > 0)
                        result = carry + result;

                        return result;





                        I/O:



                        System.out.println(add("1", "1333"));
                        1334
                        System.out.println(add("12222", "1333"));
                        13555





                        share|improve this answer



























                          1














                          You can left pad with zeroes the strings like this:



                           int longestString = Math.max(a.length(), b.length());
                          a = String.format("%1$" + longestString + "s", a).replace(' ', '0');
                          b = String.format("%1$" + longestString + "s", b).replace(' ', '0');


                          This will add leadings spaces to fill the "gap" and then replace them with zeroes.



                          Class:



                          public class Mission09 
                          public static void main(String args)
                          System.out.println(add("1", "1333"));


                          public static String add(String a, String b)
                          int carry = 0;
                          String result = "";

                          int longestString = Math.max(a.length(), b.length());

                          a = String.format("%1$" + longestString + "s", a).replace(' ', '0');
                          b = String.format("%1$" + longestString + "s", b).replace(' ', '0');


                          for (int i = a.length() - 1; i >= 0; i--)
                          int digitA = a.charAt(i) - 48;
                          int digitB = b.charAt(i) - 48;

                          int resultingNumber = digitA + digitB + carry;
                          if (resultingNumber >= 10)
                          result = (resultingNumber % 10) + result;
                          carry = 1;
                          else
                          result = resultingNumber + result;
                          carry = 0;


                          if (carry > 0)
                          result = carry + result;

                          return result;





                          I/O:



                          System.out.println(add("1", "1333"));
                          1334
                          System.out.println(add("12222", "1333"));
                          13555





                          share|improve this answer

























                            1












                            1








                            1







                            You can left pad with zeroes the strings like this:



                             int longestString = Math.max(a.length(), b.length());
                            a = String.format("%1$" + longestString + "s", a).replace(' ', '0');
                            b = String.format("%1$" + longestString + "s", b).replace(' ', '0');


                            This will add leadings spaces to fill the "gap" and then replace them with zeroes.



                            Class:



                            public class Mission09 
                            public static void main(String args)
                            System.out.println(add("1", "1333"));


                            public static String add(String a, String b)
                            int carry = 0;
                            String result = "";

                            int longestString = Math.max(a.length(), b.length());

                            a = String.format("%1$" + longestString + "s", a).replace(' ', '0');
                            b = String.format("%1$" + longestString + "s", b).replace(' ', '0');


                            for (int i = a.length() - 1; i >= 0; i--)
                            int digitA = a.charAt(i) - 48;
                            int digitB = b.charAt(i) - 48;

                            int resultingNumber = digitA + digitB + carry;
                            if (resultingNumber >= 10)
                            result = (resultingNumber % 10) + result;
                            carry = 1;
                            else
                            result = resultingNumber + result;
                            carry = 0;


                            if (carry > 0)
                            result = carry + result;

                            return result;





                            I/O:



                            System.out.println(add("1", "1333"));
                            1334
                            System.out.println(add("12222", "1333"));
                            13555





                            share|improve this answer













                            You can left pad with zeroes the strings like this:



                             int longestString = Math.max(a.length(), b.length());
                            a = String.format("%1$" + longestString + "s", a).replace(' ', '0');
                            b = String.format("%1$" + longestString + "s", b).replace(' ', '0');


                            This will add leadings spaces to fill the "gap" and then replace them with zeroes.



                            Class:



                            public class Mission09 
                            public static void main(String args)
                            System.out.println(add("1", "1333"));


                            public static String add(String a, String b)
                            int carry = 0;
                            String result = "";

                            int longestString = Math.max(a.length(), b.length());

                            a = String.format("%1$" + longestString + "s", a).replace(' ', '0');
                            b = String.format("%1$" + longestString + "s", b).replace(' ', '0');


                            for (int i = a.length() - 1; i >= 0; i--)
                            int digitA = a.charAt(i) - 48;
                            int digitB = b.charAt(i) - 48;

                            int resultingNumber = digitA + digitB + carry;
                            if (resultingNumber >= 10)
                            result = (resultingNumber % 10) + result;
                            carry = 1;
                            else
                            result = resultingNumber + result;
                            carry = 0;


                            if (carry > 0)
                            result = carry + result;

                            return result;





                            I/O:



                            System.out.println(add("1", "1333"));
                            1334
                            System.out.println(add("12222", "1333"));
                            13555






                            share|improve this answer












                            share|improve this answer



                            share|improve this answer










                            answered Nov 13 '18 at 5:43









                            RcordovalRcordoval

                            1,58411122




                            1,58411122



























                                draft saved

                                draft discarded
















































                                Thanks for contributing an answer to Stack Overflow!


                                • Please be sure to answer the question. Provide details and share your research!

                                But avoid


                                • Asking for help, clarification, or responding to other answers.

                                • Making statements based on opinion; back them up with references or personal experience.

                                To learn more, see our tips on writing great answers.




                                draft saved


                                draft discarded














                                StackExchange.ready(
                                function ()
                                StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53274293%2fhow-to-add-two-very-large-numbers-irrespective-of-their-size-in-java-without-usi%23new-answer', 'question_page');

                                );

                                Post as a guest















                                Required, but never shown





















































                                Required, but never shown














                                Required, but never shown












                                Required, but never shown







                                Required, but never shown

































                                Required, but never shown














                                Required, but never shown












                                Required, but never shown







                                Required, but never shown







                                Popular posts from this blog

                                𛂒𛀶,𛀽𛀑𛂀𛃧𛂓𛀙𛃆𛃑𛃷𛂟𛁡𛀢𛀟𛁤𛂽𛁕𛁪𛂟𛂯,𛁞𛂧𛀴𛁄𛁠𛁼𛂿𛀤 𛂘,𛁺𛂾𛃭𛃭𛃵𛀺,𛂣𛃍𛂖𛃶 𛀸𛃀𛂖𛁶𛁏𛁚 𛂢𛂞 𛁰𛂆𛀔,𛁸𛀽𛁓𛃋𛂇𛃧𛀧𛃣𛂐𛃇,𛂂𛃻𛃲𛁬𛃞𛀧𛃃𛀅 𛂭𛁠𛁡𛃇𛀷𛃓𛁥,𛁙𛁘𛁞𛃸𛁸𛃣𛁜,𛂛,𛃿,𛁯𛂘𛂌𛃛𛁱𛃌𛂈𛂇 𛁊𛃲,𛀕𛃴𛀜 𛀶𛂆𛀶𛃟𛂉𛀣,𛂐𛁞𛁾 𛁷𛂑𛁳𛂯𛀬𛃅,𛃶𛁼

                                ữḛḳṊẴ ẋ,Ẩṙ,ỹḛẪẠứụỿṞṦ,Ṉẍừ,ứ Ị,Ḵ,ṏ ṇỪḎḰṰọửḊ ṾḨḮữẑỶṑỗḮṣṉẃ Ữẩụ,ṓ,ḹẕḪḫỞṿḭ ỒṱṨẁṋṜ ḅẈ ṉ ứṀḱṑỒḵ,ḏ,ḊḖỹẊ Ẻḷổ,ṥ ẔḲẪụḣể Ṱ ḭỏựẶ Ồ Ṩ,ẂḿṡḾồ ỗṗṡịṞẤḵṽẃ ṸḒẄẘ,ủẞẵṦṟầṓế

                                ⃀⃉⃄⃅⃍,⃂₼₡₰⃉₡₿₢⃉₣⃄₯⃊₮₼₹₱₦₷⃄₪₼₶₳₫⃍₽ ₫₪₦⃆₠₥⃁₸₴₷⃊₹⃅⃈₰⃁₫ ⃎⃍₩₣₷ ₻₮⃊⃀⃄⃉₯,⃏⃊,₦⃅₪,₼⃀₾₧₷₾ ₻ ₸₡ ₾,₭⃈₴⃋,€⃁,₩ ₺⃌⃍⃁₱⃋⃋₨⃊⃁⃃₼,⃎,₱⃍₲₶₡ ⃍⃅₶₨₭,⃉₭₾₡₻⃀ ₼₹⃅₹,₻₭ ⃌