解题思路:


先将封闭图形个数计算出来(sum),再看题目数据(小于1000000000,所以sum最大也就18),于是我们有个奇妙思路:创建一个long类型的一维数组a,里面存入long类型的数据:sum*1000000000+ai(用户输入的数字),然后Arrays.sort(a)排个序,最后for循环输出“a[i]%1000000000”。检查一下,30行代码,完美解决!

这个方法省时还省力,不仅如此,它还可以运用到其他多个参数类型的题目上(比如给你一堆学生数据,然后按照“成绩-准考证”的优先级排序,诸如此类的题目...如果遇上数据太大或者数据类型过杂(int或者long 与 String —— 数字与字符串的混用),那么我们可以用String字符串类型去解决这个问题,因为String也可以排序!总之,这个方法很简单,并且代码量少,出BUG概率小!)


注意事项:

由于我的sum是long类型,所以我后面写的是“sum*1000000000+Integer.parseInt(s)”,如果你们用int类型,记得加上强转哦,否则最后输出会有问题的!“a[i]=((long)sum)*1000000000+Integer.parseInt(s);”

参考代码:

import java.util.Arrays;

import java.util.Scanner;


public class Main {


        public static void main(String[] args) {

            Scanner sc=new Scanner(System.in);

            int n=sc.nextInt();

            long[] a=new long[n];

            for (int i = 0; i < a.length; i++) {

                String s=sc.next();

                long sum=0L;

                for (int j = 0; j < s.length(); j++) {

                    if(s.charAt(j)=='4' || s.charAt(j)=='6' || s.charAt(j)=='9' || s.charAt(j)=='0') {

                        sum++;

                    }else if(s.charAt(j)=='8') {

                        sum=sum+2;

                    }

                }

                a[i]=sum*1000000000+Integer.parseInt(s);

            }

            Arrays.sort(a);

            for (int i = 0; i < a.length; i++) {

                System.out.print(a[i]%1000000000);

                if(i != a.length-1) {

                    System.out.print(" ");

                }

            }

        }

}


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论