蓝桥杯13届JAVA A组 国赛

2024-05-08 06:44
文章标签 java 蓝桥 13 国赛

本文主要是介绍蓝桥杯13届JAVA A组 国赛,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

​​​​​​​

package 蓝桥杯国赛;
// 贪心选个数最少的进行摆
// 2:1 ,3:1, 4:1,5 : 3,6:3,7:1
// 选 1,7,4,2,3,5,9
// 然后都选满10个
public class 火彩棒数字 {public static void main(String[] args){System.out.print("9999999999777777777755555555554444444444333333333322222222221111111111");}
}

package 蓝桥杯国赛;
import java.util.Scanner;
//1:无需package
//2: 类名必须Main, 不可修改
//C28 * f[i] 错排公式//f[i] = (i - 1) (f[i - 1] + f[i - 2])public class 小蓝与钥匙 {static int N = 100;static long[] f = new long[N];public static void main(String[] args) {long ans = 1;f[2] = 1; for(int i = 3;i < N;i++)f[i] = (i - 1) * (f[i - 1] + f[i - 2]);for(long i = 0;i < 14;i++)ans = ans * (28 - i) / (i + 1);System.out.println(ans * f[14]);}
}

 

package 蓝桥杯国赛;
import java.util.Scanner;public class 内存空间 {public static void main(String[] args) {Scanner in=new Scanner(System.in);int t=in.nextInt();long sum=0;in.nextLine();while(t-->0){String []s=in.nextLine().split(" ");if(s[0].equals("int")){String[]s1=s[1].split(",");sum+=4*s1.length;}else if(s[0].equals("long")){String[]s1=s[1].split(",");sum+=8*s1.length;}else if(s[0].equals("String")){String[]s1=s[1].split(",");for(String ss:s1){int index=ss.indexOf("\"");int tmp=ss.indexOf("\"",index+1)-index-1;sum+=tmp;}}else if(s[0].equals("int[]")) {for(int i=2;i<s.length;i++){int l=s[i].indexOf("[");int r=s[i].indexOf("]");int tmp=Integer.parseInt(s[i].substring(l+1,r));sum+=4*tmp;}}else if(s[0].equals("long[]")) {for(int i=2;i<s.length;i++){int l=s[i].indexOf("[");int r=s[i].indexOf("]");int tmp=Integer.parseInt(s[i].substring(l+1,r));sum+=8*tmp;}}}long gb,mb,kb,k;gb=sum/1024/1024/1024;mb=sum%(1024*1024*1024)/1024/1024;kb=sum%(1024*1024)/1024;k=sum%1024;String res="";if (gb != 0)res += gb + "GB";if (mb != 0)res += mb + "MB";if (kb != 0)res += kb + "KB";if (k != 0)res += k + "B";System.out.println(res);}}

 

package 蓝桥杯国赛;import java.util.Scanner;
// 由之前算出当n > 30 f[] > 1e6public class 斐波那契数组 {static int N = 100100;static int[] f = new int[N],a = new int[N];public static void main(String[] args){f[1] = 1;f[2] = 1;for(int i = 3;i <= 30;i++)f[i] = f[i - 1] + f[i - 2];Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();for(int i = 1;i <= n;i++)a[i] = scanner.nextInt();int ans = 0,m = n;if(n > 30) n = 30;for(int i = 1;i <= n;i++) {int cnt = 0;if(a[i] % f[i] == 0) {int t = a[i] / f[i];for(int j = 1;j <= n;j++)if(f[j] * t == a[j]) cnt++;ans = Math.max(ans,cnt);}}System.out.print(m - ans);}
}

 

package 蓝桥杯国赛;
import java.util.*;
// 特殊的dijkstra
// dijkstra是每个选取最小的,如果弹出的节点已径扩展过了,就continue
// 然后扩展每个点计算经过该点的最短路径,如果小于就原最短路径,则入堆
// 这里特殊的边权值是动态变化的
// tt < g 则当前路口为绿灯
// g < tt < g + d 则当前路口为黄灯且下一个灯为红灯
// g + d < tt < g + d + r 则当前路口为红灯
// g + d + r < tt < g + 2d + r 则当前路口为黄灯且下一个灯为绿灯 
public class 交通信号 {static final int N = 1000010, M = 4 * N;static int[] h = new int[N], e = new int[M], ne = new int[M], g = new int[M], r = new int[M], d = new int[M], f = new int[M];static long[] times = new long[N];static int idx = 0;static void add(int a, int b, int green, int red, int dist, int flag) {e[idx] = b; g[idx] = green; r[idx] = red;d[idx] = dist; ne[idx] = h[a]; f[idx] = flag; h[a] = idx++;}static long dijkstra(int n, int m, int s, int t) {Arrays.fill(times, Long.MAX_VALUE);times[s] = 0;PriorityQueue<Pair> pq = new PriorityQueue<>((a,b) -> Long.compare(a.dist,b.dist));pq.offer(new Pair(s, 0));while (!pq.isEmpty()) {Pair pair = pq.poll();int u = pair.node;long dist = pair.dist;if (dist > times[u]) continue;for (int i = h[u]; i != -1; i = ne[i]) {int j = e[i];long gr = g[i], re = r[i], di = d[i], fl = f[i];long tot = gr + re + 2 * di;long curt = dist % tot;if (fl == 1) curt = curt >= gr ? tot - curt : 0;else curt = curt >= gr + di && curt < gr + di + re ? 0 : curt < gr + di ? gr + di - curt : tot - curt + gr + di;long newDist = dist + curt + di;if (newDist < times[j]) {times[j] = newDist;pq.offer(new Pair(j, newDist));}}}return times[t] > Long.MAX_VALUE / 2 ? -1 : times[t];}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt(),m = scanner.nextInt();int s = scanner.nextInt(),t = scanner.nextInt();Arrays.fill(h, -1);for (int i = 0; i < m; i++) {int a = scanner.nextInt(), b = scanner.nextInt();int green = scanner.nextInt(),red = scanner.nextInt();int dist = scanner.nextInt();add(a, b, green, red, dist, 1); add(b, a, green, red, dist, 0);}System.out.println(dijkstra(n, m, s, t));}static class Pair {private final int node;private final long dist;public Pair(int node, long dist) {this.node = node;this.dist = dist;}}    
}

import java.util.*;public class Main {static final int MAXV = 10;static final int mod = 1000000007;static int solve(int[] B, int N) {int[][][] f = new int[2][MAXV][MAXV];int cur = 0, ans = 0;for (int i0 = 0; i0 < MAXV; ++i0) {for (int i1 = 0; i1 < MAXV; ++i1) {cur = 0;Arrays.stream(f[cur]).forEach(arr -> Arrays.fill(arr, 0));f[cur][i0][i1] = 1;for (int i = 2; i < N; i++) {cur ^= 1;Arrays.stream(f[cur]).forEach(arr -> Arrays.fill(arr, 0));for (int A0 = 0, prev = cur ^ 1; A0 < MAXV; ++A0) {for (int A1 = 0; A1 < MAXV; ++A1) {if (f[prev][A0][A1] == 0) continue;for (int A2 = 0; A2 < MAXV; ++A2) {if (Math.max(Math.max(A0, A1), A2) != B[i - 1]) continue;if (i == N - 1) {if (Math.max(Math.max(A1, A2), i0) != B[i] || Math.max(Math.max(i0, i1), A2) != B[0]) continue;}f[cur][A1][A2] += f[cur ^ 1][A0][A1];f[cur][A1][A2] %= mod;}}}}for (int A0 = 0; A0 < MAXV; ++A0) {for (int A1 = 0; A1 < MAXV; ++A1) {ans += f[cur][A0][A1];ans %= mod;}}}}return ans;}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int N = scanner.nextInt();int[] B = new int[N];for (int i = 0; i < N; ++i) {B[i] = scanner.nextInt();}System.out.println(solve(B, N));}
}

package 蓝桥杯国赛;
import java.util.*;
//本题使用bigInteger会超时
//可以利用位运算找规律
//1
//121
//12321
//1234321
//123454321
//12345654321//一共有2n-1位,
// 当i <= n 时
// 从右往左第i行,这一行有n - i + 1个 i,上面是i - 2,i - 4,.... 2(或1)
// 这一位是[(n - i + 1) * i + k] k = i/2*(i - 2)/2 或 k = (i-1) / 2*(i - 1)/2
// 当 i > n 时
// 末尾为奇数时对1到末尾相加,为偶数时0 到 n 相加public class 六六大顺 {public static void main(String[] args){Scanner scanner = new Scanner(System.in);long n = scanner.nextLong();StringBuilder x = new StringBuilder();long carry = 0, t;for (long i = 1; i <= n; i++) {t = (n - i + 1) * i;if (i % 2 == 0) t += i * (i - 2) / 4;else t += (i - 1) * (i - 1) / 4;t = t * 36 + carry;x.append(t % 10);carry = t / 10;}for (long i = n + 1; i < 2 * n; i++) {long last_value = 2 * n - i;long cnt = (last_value + 1) / 2;if (i % 2 == 0) t = (last_value + 2) * cnt / 2;else t = (last_value + 1) * cnt / 2;t = t * 36 + carry;x.append(t % 10);carry = t / 10;}x.append(carry);System.out.println(x.reverse().toString());}
}

 

package 蓝桥杯国赛;import java.util.Scanner;//x的上一层的取值范围y 为 12 ~ 22,且为合数
//当y 为 12 :9 ~ 12
//当y 为 14 :14 - 7 + 1 = 8
//当y 为 15 :15 - 5 + 1 = 9
// ····// 第一步求x 最大素数 z(如果是质数,就-1)
// y的取之范围为 (x - z + 1, x ),y为合数
// 然后在求区间中➖最大素数 + 1 最大的数 
public class 选素数 {static boolean is_prime(int n){if(n <= 1) return false;for(int i = 2;i <= n / i;i++)if(n % i == 0) return false;return true;}static int lpf(int n){int ans = 2;for(int i = 2; i <= n/i;i++){while(n % i == 0){ans = i;n /= i;}}return ans;}public static void main(String[] args){Scanner scanner = new Scanner(System.in);int x = scanner.nextInt();if(is_prime(x)) {System.out.println(-1);}else {int z = lpf(x);int l = x - z + 1;int ans = (int)2e6;for(int i = l;i <= x;i++) {if(is_prime(i)) continue;ans = Math.min(ans,i - lpf(i) + 1);}System.out.println(ans);}}
}

国赛ac难度是大于省赛的,最后俩题放弃了

这篇关于蓝桥杯13届JAVA A组 国赛的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/969597

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定