Ai
1 Star 0 Fork 0

heiheimao/java_study

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
PlusOne_66.java 1.64 KB
一键复制 编辑 原始数据 按行查看 历史
qufang 提交于 2019-01-17 16:18 +08:00 . 自己练习用
package leetCode;
import org.testng.annotations.Test;
/**
* @Description: 加一
* @Author: qufang
* @Date: Created in 下午7:58 2018/12/6
*/
public class PlusOne_66 {
public int[] plusOne(int[] digits) {
if (digits.length == 1 && digits[0] != 9) {
digits[0] = digits[0] + 1;
return digits;
} else if (digits.length == 1 && digits[0] == 9) {
int[] result = new int[digits.length + 1];
result[0] = 1;
result[1] = 0;
return result;
} else {
int i = digits.length - 1;
for (; i > 0; i--) {
if (digits[i] != 9) {
digits[i] = digits[i] + 1;
return digits;
} else if (digits[i] == 9 && digits[i - 1] != 9) {
digits[i - 1] = digits[i - 1] + 1;
for (int k = i; k < digits.length; k++) {
digits[k] = 0;
}
break;
}
}
if (i == 0) { //所有元素都是9
int[] result = new int[digits.length + 1];
result[0] = 1;
for (int k = 1; k < result.length; k++) {
result[k] = 0;
}
return result;
}
}
return digits;
}
@Test
public void test1() {
int[] digits = {1, 2, 3};
plusOne(digits);
}
@Test
public void test2() {
int[] digits = {9};
plusOne(digits);
}
@Test
public void test3() {
int[] digits = {9, 9, 9};
plusOne(digits);
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/neimenggudaxue/java_study.git
git@gitee.com:neimenggudaxue/java_study.git
neimenggudaxue
java_study
java_study
master

搜索帮助