质数拆分+明明的随机数(蓝桥杯JAVA解法)

质数拆分:用户登录

题目描述

本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。

将 2019 拆分为若干个两两不同的质数之和,一共有多少种不同的方法?

注意交换顺序视为同一种方法,例如 2+2017=2019 与 2017+2=2019 视为同一种方法。

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 128M

代码:

import java.util.Scanner;
// 1:无需package
// 2: 类名必须Main, 不可修改

public class 质数拆分 {
    static boolean st[] = new boolean[2020];
    static int primes[] = new int[2020];
    static int cnt = 1;
    static long[][] dp;
    public static void main(String[] args) {
        //筛质数
        for (int i = 2; i <= 2019; i++) {
            if (!st[i]) {
                primes[cnt++] = i;
                for (int j = i + i; j <= 2019; j += i) {
                    st[j] = true;
                }
            }
        }
        dp = new long[cnt][2020];
        dp[0][0] = 1;
        for (int i = 1; i < cnt; i++) {
            for (int j = 0; j <= 2019; j++) {
                if(j < primes[i]){ //当前背包能够放得下这个素数大小吗?
                    dp[i][j] = dp[i-1][j];
                }else{
                    dp[i][j] = dp[i-1][j]+dp[i-1][j-primes[i]];
                }
            }
        }
        System.out.println(dp[cnt-1][2019]);
    }
}

明明的随机数:用户登录

题目描述

明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了 N 个 1 到 1000 之间的随机整数(N≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去重”与“排序”的工作。

输入描述

第 1 行为 1 个正整数,表示所生成的随机数的个数:N。

第 2 行有 N 个用空格隔开的正整数,为所产生的随机数。

输出描述

输出 2 行,第 1 行为 1 个正整数 M,表示不相同的随机数的个数。

第 2 行为 M 个用空格隔开的正整数,为从小到大排好序的不相同的随机数。

输入输出样例

示例 1

输入

10
20 40 32 67 40 20 89 300 400 15

输出

8
15 20 32 40 67 89 300 400

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 128M

代码:

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.HashSet;
import java.util.Scanner;
import java.util.stream.Collectors;

public class 明明的随机数 {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int a[] = new int[n];
        for (int i = 0; i < a.length; i++) {
            a[i] = sc.nextInt();
        }
        HashSet<Integer> set = new HashSet<Integer>();
        for (int i = 0; i < a.length; i++) {
            set.add(a[i]);
        }
        System.out.println(set.size());
        ArrayList<Integer>list = new ArrayList<Integer>(set);
        Collections.sort(list);
        for (Integer i: list) {
            System.out.print(i+" ");
        }
    }

}

世人皆唱桃之夭夭,见你才知灼灼其华。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
蓝桥杯c\c++本科组决赛真题 详细 第三届“蓝桥杯”全国软件专业人才设计与创业大赛全国总决赛 C/C++程序设计本科组比赛须知(必读)  试题包含三种类型:“结果填空”、“代码填空”与“程序设计”,总计100分。 结果填空:5分 代码填空:16 分 程序设计:19+27+33 = 79分 结果填空题:要求参赛选手根据题目描述直接填写结果。求解方式不限。不要求源代码。 把结果填空的答案存入【准考证+姓名文件夹】下对应题号的“解答.txt”中即可。 代码填空题:要求参赛选手在弄清给定代码工作原理的基础上填写缺失的部分,使得程序逻辑正确、完整。所填写的代码不超过一条语句(即中间不能出现分号)。 把代码填空的答案(仅填空处的答案,不包括题面已存在的代码)存入【准考证+姓名文件夹】下对应题号的“解答.txt”中即可。 程序设计题目:要求选手设计的程序对于给定的输入能给出正确的输出结果。选手的程序只有能运行出正确结果的时候才有机会得分。注意:在评卷时使用的输入数据与试卷中给出的实例数据可能是不同的。选手的程序必须是通用的,不能只对试卷中给定的数据有效。 对每个编程题目,要求选手把所有函数写在一个文件中。调试好后,存入与【准考证+姓名文件夹】下对应题号的“解答.txt”中即可。相关的工程文件不要拷入。 对于编程题目,要求选手给出的解答完全符合ANSI C++标准,不能使用诸如绘图、Win32API、中断调用、硬件操作或与操作系统相关的API。 代码中允许使用STL类库,但不能使用MFC或ATL等非ANSI c++标准的类库。例如,不能使用CString类型(属于MFC类库)。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值