解题思路: 先整出来再说。先排序,相同的元素只打印最左边那个
注意事项:
参考代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | import java.util.Scanner; import java.util.Arrays; public class Main { public static void main(String[] args) { Scanner sc= new Scanner(System.in); int n=sc.nextInt(); int [] arr = new int [n]; for ( int i = 0 ; i < n; i++) { arr[i]=sc.nextInt(); } Arrays.sort(arr); System.out.println(Arrays.toString(arr)); int i= 0 ; while (i<n){ //打印当前元素 //相同的数 打印的都是最左边的那个 System.out.print(arr[i]+ " " ); int j=i; //记录当前打印元素的下标 while (j+ 1 <n){ //j+1=n时 到了最后一个元素 最后一个元素没有后一个元素 跳出循环 //当前打印的元素 与 其后一个元素相比 if (arr[j]==arr[j+ 1 ]){ //相同 则往后移 直到找到 下一个不同于当前打印元素的元素 j++; } else { //不同直接跳出循环 //j最后指向的是最后一个与当前相同元素的下标 break ; } } //将i指向 不同于当前元素的下一个元素 i=j+ 1 ; } } } |
8 分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复