GDPU 竞赛技能实践 天码行空 期末小测

2024-05-15 23:12

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

1. 除法(原题)

👨‍🏫 实验二:1.简单枚举
输入正整数n,按从小到大的顺序输出所有形如abcde/fghij= n的表达式,其中a~j恰好为数字0~9的一个排列(可以有前导0),2≤n≤79。

样例输入:

62

样例输出:

79546 / 01283 = 62

💖 Main1.java

import java.util.HashSet;
import java.util.Scanner;
import java.util.Set;//文件名:Main1.javapublic class Main1
{static int n;static Set<Integer> set = new HashSet<>();// 用于数字去重public static void main(String[] args){Scanner sc = new Scanner(System.in);n = sc.nextInt();for (int i = 1234; i < 100000; i++){if (repeat(i))continue;int y = cal(i);if (y != -1){System.out.print(y + "/");System.out.printf("%05d", i);System.out.println(" = " + n);}set.clear();}}/*** * @param x* @return 返回 x 对应的 x*n,非法值则返回 -1*/private static int cal(int x){int y = x * n;if (value(y))return y;return -1;}//返回 y 是否为有效值private static boolean value(int y){if (y < 10000 || y >= 100000)return false;Set<Integer> tmpSet = new HashSet<>();while (y != 0){int t = y % 10;if (tmpSet.contains(t) || set.contains(t))return false;tmpSet.add(t);y /= 10;}return true;}//返回 x 的每一位是否有重复的数字,有则返回 trueprivate static boolean repeat(int x){if ((x + "").length() == 4)x *= 10;while (x != 0){int t = x % 10;if (set.contains(t)){set.clear();return true;}set.add(t);x /= 10;}return false;}
}

在这里插入图片描述

2. 求逆序对(原题)

👨‍🏫 实验七:4. 求逆序对

输入一个序列{a1, a2, a3,…, an},交换任意两个相邻元素,不超过k次。交换之后,问最少的逆序对有多少个。

序列中的一个逆序对,是指存在两个数ai和aj,有ai > aj且1≤i<j≤n。也就是说,大的数排在小的数前面。

输入:第一行是n和k,1 ≤ n ≤ 105,0 ≤ k ≤ 109;第二行包括n个整数{a1, a2, a3,…, an},0≤ ai ≤109。

输出:最少的逆序对数量。

Sample Input:

3 1
2 2 1

Sample Output:

1

💖 Main2.java

import java.util.Scanner;public class Main2
{static int N = 100010;static int[] q = new int[N], tmp = new int[N];public static void main(String[] args){Scanner sc = new Scanner(System.in);int n = sc.nextInt();int k = sc.nextInt();for (int i = 0; i < n; i++)q[i] = sc.nextInt();long cnt = mergeSort(0, n - 1);System.out.println(Math.max(0, cnt - k));}/*** @param l 区间左边界* @param r 区间右边界* @return long 类型的区间内的逆序对*/private static long mergeSort(int l, int r){if (l >= r)return 0;int mid = l + r >> 1;long res = mergeSort(l, mid) + mergeSort(mid + 1, r);int k = 0;// 临时数组指针int i = l;// 左区间指针int j = mid + 1;// 右区间指针while (i <= mid && j <= r){if (q[i] <= q[j])// 无逆序对tmp[k++] = q[i++];else{tmp[k++] = q[j++];res += mid - i + 1;}}if (i <= mid)tmp[k++] = q[i++];if (j <= r)tmp[k++] = q[j++];for (i = l, j = 0; i <= r; i++, j++){q[i] = tmp[j];}return res;}
}

在这里插入图片描述

3. 求最大子段和(分治法)

👨‍🏫 力扣题解:53.最大子数组和

给出一个长度为 n的序列 a,选出其中连续且非空的一段使得这段和最大。

输入格式
第一行是一个整数,表示序列的长度 n。

第二行有 n 个整数,第 i 个整数表示序列的第 i个数字 ai。

输出格式
输出一行一个整数表示答案。

输入

7
2 -4 3 -1 2 -4 3

输出

4

💖 源代码

import java.util.Scanner;public class Main3
{public static void main(String[] args){Scanner sc = new Scanner(System.in);int n = sc.nextInt();int[] nums = new int[n];for (int i = 0; i < n; i++)nums[i] = sc.nextInt();int ans = maxSubArray(nums);System.out.println(ans);}public static int maxSubArray(int[] nums){int len = nums.length;if (len == 0){return 0;}return maxSubArraySum(nums, 0, len - 1);}private static int maxCrossingSum(int[] nums, int left, int mid, int right){// 一定会包含 nums[mid] 这个元素int sum = 0;int leftSum = Integer.MIN_VALUE;// 左半边包含 nums[mid] 元素,最多可以到什么地方// 走到最边界,看看最值是什么// 计算以 mid 结尾的最大的子数组的和for (int i = mid; i >= left; i--){sum += nums[i];if (sum > leftSum){leftSum = sum;}}sum = 0;int rightSum = Integer.MIN_VALUE;// 右半边不包含 nums[mid] 元素,最多可以到什么地方// 计算以 mid+1 开始的最大的子数组的和for (int i = mid + 1; i <= right; i++){sum += nums[i];if (sum > rightSum){rightSum = sum;}}return leftSum + rightSum;}private static int maxSubArraySum(int[] nums, int left, int right){if (left == right){return nums[left];}int mid = left + (right - left) / 2;return max3(maxSubArraySum(nums, left, mid), maxSubArraySum(nums, mid + 1, right),maxCrossingSum(nums, left, mid, right));}private static int max3(int num1, int num2, int num3){return Math.max(num1, Math.max(num2, num3));}
}

在这里插入图片描述

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



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

相关文章

jdk1.8的Jenkins安装配置实践

《jdk1.8的Jenkins安装配置实践》Jenkins是一款流行的开源持续集成工具,支持自动构建、测试和部署,通过Jenkins,开发团队可以实现代码提交后自动进行构建、测试,并将构建结果分发到测... 目录Jenkins介绍Jenkins环境搭建Jenkins安装配置Jenkins插件安装Git安装配

SpringBoot的全局异常拦截实践过程

《SpringBoot的全局异常拦截实践过程》SpringBoot中使用@ControllerAdvice和@ExceptionHandler实现全局异常拦截,@RestControllerAdvic... 目录@RestControllerAdvice@ResponseStatus(...)@Except

mysql_mcp_server部署及应用实践案例

《mysql_mcp_server部署及应用实践案例》文章介绍了在CentOS7.5环境下部署MySQL_mcp_server的步骤,包括服务安装、配置和启动,还提供了一个基于Dify工作流的应用案例... 目录mysql_mcp_server部署及应用案例1. 服务安装1.1. 下载源码1.2. 创建独立

SpringBoot简单整合ElasticSearch实践

《SpringBoot简单整合ElasticSearch实践》Elasticsearch支持结构化和非结构化数据检索,通过索引创建和倒排索引文档,提高搜索效率,它基于Lucene封装,分为索引库、类型... 目录一:ElasticSearch支持对结构化和非结构化的数据进行检索二:ES的核心概念Index:

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

MySQL存储过程实践(in、out、inout)

《MySQL存储过程实践(in、out、inout)》文章介绍了数据库中的存储过程,包括其定义、优缺点、性能调校与撰写,以及创建和调用方法,还详细说明了存储过程的参数类型,包括IN、OUT和INOUT... 目录简述存储过程存储过程的优缺点优点缺点存储过程的创建和调用mysql 存储过程中的关键语法案例存储

Java 的ArrayList集合底层实现与最佳实践

《Java的ArrayList集合底层实现与最佳实践》本文主要介绍了Java的ArrayList集合类的核心概念、底层实现、关键成员变量、初始化机制、容量演变、扩容机制、性能分析、核心方法源码解析、... 目录1. 核心概念与底层实现1.1 ArrayList 的本质1.1.1 底层数据结构JDK 1.7

JDK21对虚拟线程的几种用法实践指南

《JDK21对虚拟线程的几种用法实践指南》虚拟线程是Java中的一种轻量级线程,由JVM管理,特别适合于I/O密集型任务,:本文主要介绍JDK21对虚拟线程的几种用法,文中通过代码介绍的非常详细,... 目录一、参考官方文档二、什么是虚拟线程三、几种用法1、Thread.ofVirtual().start(

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础