首尾数字之和

huangapple go评论61阅读模式
英文:

Sum of first and last digit

问题

我已经编写了一段代码,在这段代码中,我想要添加第一个和最后一个数字。我的代码涵盖了1位数、2位数和3位数的情况,但不包括4位数。此外,我认为我的代码不够简单和高效,我想要使用一个while循环来处理所有情况。有人可以帮忙吗?

public static void main(String[] args) {
    System.out.println(sumFirstAndLastDigit(10));
}

public static int sumFirstAndLastDigit(int number) {
    int mod = 0;
    int firstdivide = 0;
    int seconddivide = 0;
    int sum = 0;

    if (number < 0) {
        return -1;
    } else if (number > 0 && number < 10) {
        return number + number;
    } else if (number >= 10 && number < 100) {
        mod = number % 10;
        firstdivide = number / 10;
        sum = mod + firstdivide;

        return sum;
    }

    while (number > 0) {
        mod = number % 10;
        firstdivide = number / 10;
        seconddivide = firstdivide / 10;
        sum = mod + seconddivide;

        break;
    }

    return sum;
}
英文:

I have written a code where I want to add the first and last digit. My code covers scenarios of 1 digit and 2 digits and 3 digits, but not 4 digits. Also, I don't think my code is very simple and efficient, I want to use a while loop to cover all scenarios. Can anyone help, please?

public static void main(String[] args) {
    System.out.println(sumFirstAndLastDigit(10));
}

public static int sumFirstAndLastDigit(int number) {
    int mod = 0;
    int firstdivide = 0;
    int seconddivide = 0;
    int sum = 0;

    if (number &lt; 0) {
        return -1;
    } else if (number &gt; 0 &amp;&amp; number &lt; 10) {
        return number + number;
    } else if (number &gt;= 10 &amp;&amp; number &lt; 100) {
        mod = number % 10;
        firstdivide = number / 10;
        sum = mod + firstdivide;

        return sum;
    }

    while (number &gt; 0) {
        mod = number % 10;
        firstdivide = number / 10;
        seconddivide = firstdivide / 10;
        sum = mod + seconddivide;

        break;
    }

    return sum;
}

</details>


# 答案1
**得分**: 3

用一点数学,你可以轻松地提取一个数字的第一个和最后一个数字。最后(最右边)的数字可以通过取模来得到,而第一个(最左边)的数字可以通过计算以10为底的对数来获得。

```java
public static int sumFirstAndLastDigit(int number) {
    if (number < 0) {
        return -1;
    }

    int lastDigit = number % 10;
    int digits = (int) Math.log10(number); // 数字的位数减1
    int firstDigit = (int) (number / Math.pow(10, digits));

    return lastDigit + firstDigit;
}
英文:

With a little bit of math, you can easily extract the first and last digit of a number. The last (rightmost) digit is simple with modulo, the first (leftmost) digit can be obtained by calculating the base 10 logarithm of the number.

public static int sumFirstAndLastDigit (int number) {
    if (number &lt; 0) {
        return -1;
    }

    int lastDigit = number % 10;
    int digits = (int)Math.log10(number); // number of digits - 1 
    int firstDigit = (int)(number / Math.pow(10, digits));

    return lastDigit + firstDigit;
}

答案2

得分: 2

你的 while 循环不正确。它将在执行 1 次迭代后总是中断。

if (number < 0) {
    return -1;
}
// 获取个位数
int mod = number % 10;
// 不断除以 10直到只剩下 1 位数字
while (number > 9) {
    number /= 10;
}
return mod + number;
英文:

Your while loop is not correct. It will always break after 1 iteration.

if (number &lt; 0) {
    return -1;
}
// Get ones digit
int mod = number % 10;
// Keep dividing until only 1 digit left
while (number &gt; 9) {
    number /= 10;
}
return mod + number;

答案3

得分: 1

以下是翻译好的部分:

private static int sumOfFirstAndLastDigits(final int input) {
   int number = Math.abs(input);
   final int lastDigit = number % 10;
   while (number &gt; 9)
       number = number / 10;
   return number + lastDigit;
}
英文:

How about this simple one:

private static int sumOfFirstAndLastDigits(final int input) {
   int number = Math.abs(input);
   final int lastDigit = number % 10;
   while (number &gt; 9)
       number = number / 10;
   return number + lastDigit;
}

huangapple
  • 本文由 发表于 2020年9月30日 02:34:24
  • 转载请务必保留本文链接:https://go.coder-hub.com/64125626.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定