减一运算(java)求帮助
给定一个由正整数组成的非空数组,也就是一个正整数N(1<N<101000)的各位数字,其中最高位数字存放在数组的首位,且每个数组元素只存储一位数字。
请求出N-1对应的新数组并输出。
假设除了整数0之外,数组的首元素不会是零。
减一运算, 给定一个由正整数组成的非空数组, 请求出N-1对应的新数组并输出。(java)
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- CSDN专家-sinJack 2022-02-23 17:29关注
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String str = sc.nextLine(); String[] s = str.split(" "); int n = s.length; int[] my = new int[n]; int j=1; for(int i= 0 ; i < n; i++){ my[i] = Integer.parseInt(s[i]);//化为int型数组 } if(my[n-1] != 0){ my[n-1] = my[n-1] - 1; for(int s1:my){ System.out.print(s1 + " "); } } else{ my[n-1]=9; for(;my[n-j-1] == 0; j++){//直到遍历到不为0的位置跳出 if(n-j-1>=0){ my[n-j-1] = 9; } else break; } my[n-j-1] = my[n-j-1]-1;//跳出后,这里不为0的数字借1,也就是他自己减1 if(my[0] == 0){//如果首位是1,他借1后变为0,不能输出0 for(int i=1; i<n;i++){ System.out.print(my[i] + " "); } } else{ for(int s1:my){ System.out.print(s1 + " "); } } } } }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥20 机器学习能否像多层线性模型一样处理嵌套数据
- ¥20 西门子S7-Graph,S7-300,梯形图
- ¥50 用易语言http 访问不了网页
- ¥50 safari浏览器fetch提交数据后数据丢失问题
- ¥15 matlab不知道怎么改,求解答!!
- ¥15 永磁直线电机的电流环pi调不出来
- ¥15 用stata实现聚类的代码
- ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
- ¥20 docker里部署springboot项目,访问不到扬声器
- ¥15 netty整合springboot之后自动重连失效