GDPU 竞赛技能实践 天码行空9

2024-04-27 21:44

本文主要是介绍GDPU 竞赛技能实践 天码行空9,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 埃式筛法

求区间[2, n]内所有的素数对

💖 Main.java

import java.util.Scanner;public class Main
{static int N = (int) 1e8, cnt = 0;static int[] p = new int[N];static boolean[] st = new boolean[N];public static void main(String[] args){Scanner sc = new Scanner(System.in);int n = sc.nextInt();getPrimes(n);print();}private static void print(){for (int i = 0; i < cnt; i++)System.out.print(p[i] + " ");}private static void getPrimes(int n){for (int i = 2; i <= n && i < N; i++){if (!st[i]){p[cnt++] = i;for (int j = 2; j * i <= n; j++)st[i * j] = true;}}}}

在这里插入图片描述

2. 求第1亿个Fibonacci数

👨‍🏫 参考地址

💖 Main.java

public class Main
{static long n, p;//	龟速乘法(快速积)static long qmul(long a, long b){long res = 0;while (b != 0){if ((b & 1) == 1){res = (res + a) % p;}a = (a + a) % p;b >>= 1;}return res;}//	矩阵乘法static void mul(long[][] a, long[][] b){
//		临时矩阵暂存结果long[][] tmp = new long[2][2];for (int i = 0; i < 2; i++)for (int j = 0; j < 2; j++)for (int k = 0; k < 2; k++)tmp[i][j] = (tmp[i][j] + qmul(a[i][k], b[k][j])) % p;//		拷贝for (int i = 0; i < 2; i++)for (int j = 0; j < 2; j++)a[i][j] = tmp[i][j];}//	计算斐波那契数列的第 n 项static long F(long n){
//		极端情况if (n == 0)return 0;//		根据fn来进行构造矩阵// fn,分别为f(1) f(2)long[][] f = { { 1, 1 }, { 0, 0 } };// 累乘矩阵long[][] a = { { 0, 1 }, { 1, 1 } };//      快速幂for (long k = n - 1; k != 0; k >>= 1){if ((k & 1) == 1)mul(f, a);mul(a, a);}return f[0][0];}public static void main(String[] args){n = (int) 1e8;// 10^8 == 1 亿p = Integer.MAX_VALUE; // 由于会爆int long 需要取模System.out.println("前20项:");for (int i = 0; i < 20; i++)System.out.print(F(i) + " ");System.out.println();System.out.println("第1亿项:" + F(n));}
}

在这里插入图片描述

3.Catalan数

即卡特兰数又称卡塔兰数,是组合数学中一个常出现在各种计数问题中的数列,以比利时的数学家欧仁·查理·卡塔兰 (1814–1894)的名字来命名。现请你写一段程序来计算Catalan数。
输入样例:

5

输出样例:

42

💖 Main.java

import java.util.Scanner;public class 卡特兰数
{static long cal(int n){long son = 1;long mum = 1;for (int i = 2 * n; i > n; i--)son *= i;for (int i = n; i >= 1; i--)mum *= i;return son / (mum * (n + 1));}public static void main(String[] args){Scanner sc = new Scanner(System.in);int n = sc.nextInt();System.out.println(cal(n));}
}

在这里插入图片描述

4. 摆球

现将大小和形状相同的4个黑色球和4个红色球排成一排,从左边第一个球开始数,不管数几个不球,黑球数不少于红球数的排法有多少种?请编程实现。
卡特兰数的应用

💖 Main.java

public class Main
{static int N = 8;static long ans = 0;static long ans1 = 0;public static void main(String[] args){dfs(0, 0, 0);System.out.println(ans + " " + cal(4));}//	卡特兰数static long cal(int n){long son = 1;long mum = 1;for (int i = 2 * n; i > n; i--)son *= i;for (int i = n; i >= 1; i--)mum *= i;return son / (mum * (n + 1));}//	暴力枚举private static void dfs(int cur, int black, int red){if (cur >= 8){if (red == 4 && black == 4)ans++;return;}if (black > red)dfs(cur + 1, black, red + 1);dfs(cur + 1, black + 1, red);}}

在这里插入图片描述

这篇关于GDPU 竞赛技能实践 天码行空9的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

SQLite3命令行工具最佳实践指南

《SQLite3命令行工具最佳实践指南》SQLite3是轻量级嵌入式数据库,无需服务器支持,具备ACID事务与跨平台特性,适用于小型项目和学习,sqlite3.exe作为命令行工具,支持SQL执行、数... 目录1. SQLite3简介和特点2. sqlite3.exe使用概述2.1 sqlite3.exe

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Springboot整合Redis主从实践

《Springboot整合Redis主从实践》:本文主要介绍Springboot整合Redis主从的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言原配置现配置测试LettuceConnectionFactory.setShareNativeConnect

java中Optional的核心用法和最佳实践

《java中Optional的核心用法和最佳实践》Java8中Optional用于处理可能为null的值,减少空指针异常,:本文主要介绍java中Optional核心用法和最佳实践的相关资料,文中... 目录前言1. 创建 Optional 对象1.1 常规创建方式2. 访问 Optional 中的值2.1

Nginx Location映射规则总结归纳与最佳实践

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则... 目录一、Location匹配规则与优先级1. 匹配模式2. 优先级顺序3. 匹配示例二、Proxy_pa

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

pytest+allure环境搭建+自动化实践过程

《pytest+allure环境搭建+自动化实践过程》:本文主要介绍pytest+allure环境搭建+自动化实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、pytest下载安装1.1、安装pytest1.2、检测是否安装成功二、allure下载安装2.