2020第十一届 蓝桥杯模拟赛(JAVA)

文章目录

  • 一、内存转换
    • 问题描述
    • 解题思路
  • 二、求约数
    • 问题描述
    • 解题思路
  • 三、九
    • 问题描述
    • 解题思路
  • 四、树
    • 问题描述
    • 解题思路
  • 五、递增数
    • 问题描述
    • 解题思路
  • 六、四段字母
    • 问题描述
    • 解题思路
  • 七、递增三元组
    • 问题描述
    • 解题思路
  • 八、正整数序列
    • 问题描述
    • 解题思路
  • 九、种草
    • 问题描述
    • 解题思路
  • 十、晚会节目
    • 问题描述
    • 解题思路

一、内存转换

问题描述

在计算机存储中,15.125GB是多少MB?
答案提交
  这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

解题思路

答案:15488


二、求约数

问题描述

1200000有多少个约数(只计算正约数)。
答案提交
  这是一道结果填空的题,你只需要算出结果后提交即可。
本题的结果为一个整数,在提交答案时只填写这个整数,
填写多余的内容将无法得分。

解题思路

枚举

/**
 * @author sjf
 * @date 2020/3/23 20:07
 */



public class demo02求约数 {
    public static void main(String[] args) {

        int num = 1200000;
        int count = 0;
        for (int i = 1; i <= num ; i++) {
            if(num%i == 0){
                count++;
                System.out.println(i);
            }
        }
        System.out.println(count);  //96
    }
}


三、九

问题描述

在1至2019中,有多少个数的数位中包含数字9?
  注意,有的数中的数位中包含多个9,这个数只算一次。
例如,1999这个数包含数字9,在计算只是算一个数。
答案提交
  这是一道结果填空的题,你只需要算出结果后提交即可。
本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

解题思路

求每一位即可

/**
 * @author sjf
 * @date 2020/3/23 20:13
 */



public class demo03位数 {
    public static void main(String[] args) {
        int count = 0;
        for (int i = 1; i <= 2019 ; i++) {
            int temp = i;
            while (temp != 0){
                int yu = temp%10;
                temp/=10;
                if(yu == 9) {
                    count++;
                    System.out.println(i);
                    break;
                }
            }

        }
        System.out.println(count);  //544
    }
}


四、树

问题描述

一棵包含有2019个结点的树,最多包含多少个叶结点?
答案提交
  这是一道结果填空的题,你只需要算出结果后提交即可。
本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

解题思路

//没有子结点的结点 称作 叶节点
//没有父节点的结点 称作 根节点
System.out.println(2018); //最多 这个树只有两层


五、递增数

问题描述

一个正整数如果任何一个数位不大于右边相邻的数位,则称为一个数位递增的数。
例如1135是一个数位递增的数,而1024不是一个数位递增的数。

给定正整数 n,请问在整数 1 至 n 中有多少个数位递增的数?
输入格式
  输入的第一行包含一个整数 n。
输出格式
  输出一行包含一个整数,表示答案。
样例输入
30
样例输出
26
评测用例规模与约定
  对于 40% 的评测用例,1 <= n <= 1000。
  对于 80% 的评测用例,1 <= n <= 100000。
  对于所有评测用例,1 <= n <= 1000000。

时间 1s

解题思路

转换字符 排序 比较 不用求出每一位(比如404用求数位比较的方法不容易做的)
具体看代码吧


import java.util.Arrays;
import java.util.Scanner;

/**
 * @author sjf
 * @date 2020/3/23 20:21
 */



//不用拆分每一位
//输入 排序 然后 比较
public class demo05递增数 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String s;
        s = sc.next();
        char[] num = s.toCharArray();

        char[] numTemp =s.toCharArray();

        Arrays.sort(numTemp);
        int i =0 ;
        for (i = 0; i <num.length ; i++) {
            if(num[i]!=numTemp[i])
                break;
        }

        if(i==num.length)
            System.out.println(s);

    }
}


六、四段字母

问题描述

小明对类似于 hello 这种单词非常感兴趣,这种单词可以正好分为四段,
第一段由一个或多个辅音字母组成,
第二段由一个或多个元音字母组成,
第三段由一个或多个辅音字母组成,
第四段由一个或多个元音字母组成。
  给定一个单词,请判断这个单词是否也是这种单词,如果是请输出yes,否则请输出no。
  元音字母包括 a, e, i, o, u,共五个,其他均为辅音字母。
输入格式
  输入一行,包含一个单词,单词中只包含小写英文字母。
输出格式
  输出答案,或者为yes,或者为no。
样例输入
lanqiao
样例输出
yes
样例输入
world
样例输出
no
评测用例规模与约定
  对于所有评测用例,单词中的字母个数不超过100。

解题思路

遍历一遍字母吧 根据题目要求 进行分段

import java.util.Scanner;

/**
 * @author sjf
 * @date 2020/3/23 20:35
 */



public class demo06四段字母 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        String sF = sc.next();

        String s = sF+"6";
        int flag = 0;
        int count = 0;
        for (int i = 0; i < s.length(); ) {
            char c = s.charAt(i);
            //辅音
            while (i < s.length() - 1 && (c != 'a' && c != 'e' && c != 'i' && c != 'o' && c != 'u')) {
                i++;
                c = s.charAt(i);
            }
            flag++;
            if(i == sF.length())
                break;
            //元音
            while (i < s.length() - 1  && (c == 'a' || c == 'e' || c == 'i' || c == 'o' || c == 'u')){
                i++;
                c = s.charAt(i);
            }
            flag++;
            if(i == sF.length())
                break;

        }

        if (flag == 4)
            System.out.println("yes");
        else
            System.out.println("no");
    }
}


七、递增三元组

问题描述

在数列 a[1], a[2], …, a[n] 中,如果对于下标 i, j, k 满足 0 则称 a[i], a[j], a[k] 为一组递增三元组,a[j]为递增三元组的中心。
  给定一个数列,请问数列中有多少个元素可能是递增三元组的中心。
输入格式
  输入的第一行包含一个整数 n。
  第二行包含 n 个整数 a[1], a[2], …, a[n],相邻的整数间用空格分隔,表示给定的数列。
输出格式
  输出一行包含一个整数,表示答案。
样例输入
5
1 2 5 3 5
样例输出
2
样例说明
  a[2] 和 a[4] 可能是三元组的中心。
评测用例规模与约定
  对于 50% 的评测用例,2 <= n <= 100,0 <= 数列中的数 <= 1000。
  对于所有评测用例,2 <= n <= 1000,0 <= 数列中的数 <= 10000。

解题思路

枚举 注意计数 是个坑

import java.util.ArrayList;
import java.util.Scanner;

/**
 * @author sjf
 * @date 2020/3/23 22:25
 */


public class demo07递增三元组 {
    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();
        }
        int i=0,j=0,k =0 ;
        ArrayList<Integer> ans = new ArrayList<>();
        for ( i = 0; i < n-2; i++) {
            for ( j = i+1; j < n-1 ; j++) {
                if(arr[i]<arr[j])
                for (k = j+1; k < n; k++) {
                    if ( arr[j]<arr[k]){
                        if(!ans.contains(j))
                            ans.add(j);
                        break;
                    }
                }
            }
        }
        System.out.println(ans.size());
    }
}


八、正整数序列

问题描述

小明想知道,满足以下条件的正整数序列的数量:
  1. 第一项为 n;
  2. 第二项不超过 n;
  3. 从第三项开始,每一项小于前两项的差的绝对值。
  请计算,对于给定的 n,有多少种满足条件的序列。
输入格式
  输入一行包含一个整数 n。
输出格式
  输出一个整数,表示答案。答案可能很大,请输出答案除以10000的余数。
样例输入
4
样例输出
7
样例说明
  以下是满足条件的序列:
  4 1
  4 1 1
  4 1 2
  4 2
  4 2 1
  4 3
  4 4
评测用例规模与约定
  对于 20% 的评测用例,1 <= n <= 5;
  对于 50% 的评测用例,1 <= n <= 10;
  对于 80% 的评测用例,1 <= n <= 100;
  对于所有评测用例,1 <= n <= 1000。

解题思路

找规律 水 。。

import java.util.Scanner;

/**
 * @author sjf
 * @date 2020/3/23 22:41
 */



/*
经典 递归找规律了

规律
f(n) = f(n-1)+f(n-2)+f(n-3);
 */
public class demo08正整数序列 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        int num = sc.nextInt();

        int a1 = 2;
        int a2 = 2;
        int a3 = 3;
        int a4 = 0;
        if(num == 1)
            System.out.println(a1);
        if(num == 2)
            System.out.println(a2);
        if(num == 3)
            System.out.println(a3);
        for (int i = 4; i <= num ; i++) {
            a4 = (a1+a2+a3)%10000;
            a1 = a2;
            a2 = a3;
            a3 =a4;
        }
        if(num>=4)
        System.out.println(a4);

    }



}


九、种草

问题描述

小明有一块空地,他将这块空地划分为 n 行 m 列的小块,每行和每列的长度都为 1。
  小明选了其中的一些小块空地,种上了草,其他小块仍然保持是空地。
  这些草长得很快,每个月,草都会向外长出一些,如果一个小块种了草,则它将向自己的上、下、左、右四小块空地扩展,这四小块空地都将变为有草的小块。
  请告诉小明,k 个月后空地上哪些地方有草。
输入格式
  输入的第一行包含两个整数 n, m。
  接下来 n 行,每行包含 m 个字母,表示初始的空地状态,字母之间没有空格。如果为小数点,表示为空地,如果字母为 g,表示种了草。
  接下来包含一个整数 k。
输出格式
  输出 n 行,每行包含 m 个字母,表示 k 个月后空地的状态。如果为小数点,表示为空地,如果字母为 g,表示长了草。
样例输入
4 5
.g…

…g…

2
样例输出
gggg.
gggg.
ggggg
.ggg.
评测用例规模与约定
  对于 30% 的评测用例,2 <= n, m <= 20。
  对于 70% 的评测用例,2 <= n, m <= 100。
  对于所有评测用例,2 <= n, m <= 1000,1 <= k <= 1000。

解题思路

经典dfs题了 水
标记
进行草的扩张
输出

import java.util.Scanner;

/**
 * @author sjf
 * @date 2020/3/23 22:55
 */


/*
经典 dfs了 着色问题
 */
public class demo09种草 {
    static char[][] map = new char[1001][1001];
    static int[][] book = new int[1001][1001];
    static int n,m;
    static int k;
    static int[][] swap = {{0,1},{1,0},{0,-1},{-1,0}};

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
         n=sc.nextInt();
         m=sc.nextInt();

        for (int i = 0; i <n ; i++) {
            String s = sc.next();
            map[i] =s.toCharArray();
        }
        k = sc.nextInt();
        for (int i = 0; i < n ; i++) {
            for (int j = 0; j < m; j++) {
                if(map[i][j] == 'g')
                    book[i][j] = 1;
            }
        }

        for (int i = 0; i < n; i++) {
            for (int j = 0; j < m ; j++) {
                if(book[i][j] == 1)
                    dfs(i,j,0);
            }
        }


        for (int i = 0; i < n ; i++) {
            for (int j = 0; j < m; j++) {
                System.out.print(map[i][j]);
            }
            System.out.println();
        }
    }

    public static void dfs(int x ,int y ,int month){
        if(month == k)
            return;

        int tx = 0,ty = 0 ;
        for (int i = 0; i < 4 ; i++) {
            tx = x + swap[i][0];
            ty = y + swap[i][1];

            if(tx<0||tx>=n||ty<0||ty>=m)
                continue;

                map[tx][ty] = 'g';
                dfs(tx, ty, month + 1);
        }

    }

}


十、晚会节目

问题描述

小明要组织一台晚会,总共准备了 n 个节目。然后晚会的时间有限,他只能最终选择其中的 m 个节目。
  这 n 个节目是按照小明设想的顺序给定的,顺序不能改变。
  小明发现,观众对于晚上的喜欢程度与前几个节目的好看程度有非常大的关系,他希望选出的第一个节目尽可能好看,在此前提下希望第二个节目尽可能好看,依次类推。
  小明给每个节目定义了一个好看值,请你帮助小明选择出 m 个节目,满足他的要求。
输入格式
  输入的第一行包含两个整数 n, m ,表示节目的数量和要选择的数量。
  第二行包含 n 个整数,依次为每个节目的好看值。
输出格式
  输出一行包含 m 个整数,为选出的节目的好看值。
样例输入
5 3
3 1 2 5 4
样例输出
3 5 4
样例说明
  选择了第1, 4, 5个节目。
评测用例规模与约定
  对于 30% 的评测用例,1 <= n <= 20;
  对于 60% 的评测用例,1 <= n <= 100;
  对于所有评测用例,1 <= n <= 100000,0 <= 节目的好看值 <= 100000。

解题思路

不会 有关于动态规划
题解待更新

你可能感兴趣的:(蓝桥杯)