藍橋杯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難度是大于省賽的,最后倆題放棄了

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/10089.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/10089.shtml
英文地址,請注明出處:http://en.pswp.cn/web/10089.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【CTFHub】HTTP 請求方式 302跳轉 cookie WP

1.請求方式 打開給出的URL進入一個頁面&#xff0c;提示原方法是GET&#xff0c;用CTFHUB方法就能獲得flag 思路&#xff1a;抓包&#xff0c;將GET方法改成CTFHUB方法進行重新發送請求&#xff0c;查看響應情況 1.打開代理服務器 2.打開BurpSuite 刷新頁面獲得攔截 3.發送…

【Excel VBA】深入理解 VBA 中的 CallByName 函數

動態調用方法與屬性&#xff1a;深入理解 VBA 中的 CallByName 函數 昨天在介紹Choose函數在復雜的VBA應用程序開發中&#xff0c;有時我們需要根據運行時的情況來決定調用哪個對象的哪個方法或屬性。這種靈活性可以通過 CallByName 函數實現。在本篇博客中&#xff0c;田辛老…

網絡Http和Socket通訊(基于面試)

每日一句&#xff1a;想得到世上最好的東西&#xff0c;先得讓世界看到最好的你 目錄 面試問OSI或TCP/IP,怎么回答&#xff1f; 面試問HTTP&#xff1f; 面試問Get類型&#xff0c;Pot類型區別&#xff1f; 面試什么是Socket套接字&#xff1f; 面試問什么是數據粘包&…

qt for android 的架構原理

qt for android實現架構&#xff0c;分享這幾幅很不錯圖。來自于 《Qt 林斌&#xff1a;整合Android IVI平臺打造統一的Qt數字座艙體驗》 1.實現架構圖 2.qt for android能力 3.java 和 qt混合開發 4. AutoMotive

46寸硅片為什么要留平邊(flat)?

知 識星球&#xff08;星球名&#xff1a; 芯片制造與封測社區&#xff0c;星球號&#xff1a; 63559049&#xff09;里的學員問&#xff1a; 2&#xff0c; 4&#xff0c; 6寸硅片都有 平 邊&#xff0c;它們有什么作用 &#xff1f; 硅片的平邊&#xff08;Flat&…

經典權限五張表案例分析

文章目錄 模塊分析模塊分析 描述五張表的關系重要知識講解抽取成一個BaseServletSpringIOC思想(底層)實現代碼IOC概述 SPI機制(為學習框架做思想和技術鋪墊)SPI引入1. 標準/規范2. 具體的實現3. 調用 SPI介紹SPI練習JDBC4.0免注冊驅動原理Servlet實現方式三 ServletContainerIn…

idea使用前的全局配置,一次配置,多次使用

前提&#xff1a;每次導入一個新的項目&#xff0c;就需要重新設置編碼、maven、jdk、git版本等信息。實際每個項目所用到的配置信息是一致的&#xff0c;除非換一家公司&#xff0c;不然不會改動到這些內容。 idea版本&#xff1a;2024.1.1 1.1、全局Maven配置 IDEA啟動頁面…

微火一文盤點:為何全域運營系統會成為創業新風口?

當前&#xff0c;微火全域運營已經成為創業的新風口&#xff0c;想要做微火全域運營服務商的創業者數量日益增多。據目前了解到的最新消息&#xff0c;微火全域運營系統的市場占有率已經超過了48%&#xff0c;并且還在持續不斷地上漲中。 所謂微火全域運營系統&#xff0c;就是…

InLine Chat功能優化對標Github Copilot,CodeGeeX帶來更高效、更直觀的編程體驗!

VSCode中的CodeGeeX 插件上線InLine Chat功能后&#xff0c;收到不少用戶的反饋&#xff0c;大家對行內交互編程這一功能非常感興趣。近期我們針對這個功能再次進行了深度優化&#xff0c;今天詳細介紹已經在VSCode插件v2.8.0版本上線的 CodeGeeX InLine Chat功能&#xff0c;以…

藍橋杯成績已出

藍橋杯的成績早就已經出來了&#xff0c;雖然沒有十分驚艷 &#xff0c;但是對于最終的結果我是心滿意足的&#xff0c;感謝各位的陪伴&#xff0c;關于藍橋杯的刷題筆記我已經堅持更新了49篇&#xff0c;但是現在即將會告別一段落&#xff0c;人生即將進入下一個規劃。我們一起…

Spring框架學習筆記(一):Spring基本介紹(包含IOC容器底層結構)

1 官方資料 1.1 官網 https://spring.io/ 1.2 進入 Spring5 下拉 projects, 進入 Spring Framework 進入 Spring5 的 github 1.3 在maven項目中導入依賴 <dependencies><!--加入spring開發的基本包--><dependency><groupId>org.springframework<…

jni 返回二維byte數組

在JNI中返回二維byte數組&#xff0c;你需要在Java中準備一個相應的二維數組來接收這個返回值。在JNI層面&#xff0c;你可以創建一個二維的byte數組&#xff0c;并使用GetByteArrayRegion和SetByteArrayRegion來操作它。 以下是一個簡單的例子&#xff1a; public class Jni…

基于STC12C5A60S2系列1T 8051單片機實現一主單片機與一從單片機進行雙向串口通信功能

基于STC12C5A60S2系列1T 8051單片機實現一主單片機與一從單片機進行雙向串口通信功能 STC12C5A60S2系列1T 8051單片機管腳圖STC12C5A60S2系列1T 8051單片機串口通信介紹STC12C5A60S2系列1T 8051單片機串口通信的結構基于STC12C5A60S2系列1T 8051單片機串口通信的特殊功能寄存器…

QT---day5,通信

1、思維導圖 2、TCp 服務器 #ifndef MYWIDGET_H #define MYWIDGET_H #include <QWidget> #include <QTcpServer> #include <QList> #include <QTcpSocket> #include <QMessageBox> #include <QDebug> #include <QTcpServer> QT_B…

鐳速實現利用Libarchive實現高效、智能的文件傳輸和管理

在前一篇報道中&#xff0c;我們闡述了Libarchive這一開源庫的強大功能&#xff0c;它專門用于處理歸檔文件。通過整合Libarchive&#xff0c;鐳速在包括Windows和Linux在內的多個操作系統上提供了在線解壓縮服務&#xff0c;為企業構建了一個既強大又安全的文件傳輸系統&#…

【代碼分享】使用HTML5的Canvas繪制編碼說明圖片

最急在工作中遇到一個需求&#xff0c;根據給定的編碼生成編碼說明&#xff0c;像下面這樣的效果。 不同含義的編碼用橫杠分割&#xff0c;然后每個編碼下面用箭頭指明具體的含義。下面是我使用canvas實現的代碼。具體的編碼寬度大家可以根據實際情況進行調整&#xff0c;目前…

Ranger 面試題及答案整理,最新面試題

Ranger 的安全模型是如何設計的&#xff1f; Ranger的安全模型設計主要基于訪問控制和安全策略的管理&#xff0c;它通過以下幾個關鍵組件實現&#xff1a; 1、策略管理&#xff1a; Ranger 提供了一個中央管理平臺&#xff0c;用于定義、更新和管理安全策略。這些策略根據資…

基于RT-Thread的HC-SR04超聲波驅動

前言 本次驅動用的是這款超聲波&#xff0c;超聲波的驅動大同小異&#xff0c;均可參考 一、引腳定義 引腳功能VCC接直流5V電TRIG接外部電路的TRIG端&#xff0c;向此引腳輸入10us以上的高電平可觸發超聲波測距ECHO接外部電路的ECHO端&#xff0c;測距結束時該引腳會輸出一…

Python框架Django入門教程

Django 是一個使用 Python 編程語言開發的、免費且開源的 Web 應用框架。它遵循 "DRY&#xff08;Dont Repeat Yourself&#xff09;" 原則&#xff0c;旨在簡化創建功能豐富的、高效率的 Web 網站。Django 提供了模型-視圖-控制器&#xff08;MVC&#xff09;架構的…