news 2026/1/10 15:40:47

(新卷,200分)- 数字序列比大小(Java JS Python C)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(新卷,200分)- 数字序列比大小(Java JS Python C)

(新卷,200分)- 数字序列比大小(Java & JS & Python & C)

题目描述

A,B两个人玩一个数字比大小的游戏,在游戏前,两个人会拿到相同长度的两个数字序列,两个数字序列不相同的,且其中的数字是随机的。

A,B各自从数字序列中挑选出一个数字进行大小比较,赢的人得1分,输的人扣1分,相等则各自的分数不变。 用过的数字需要丢弃。

求A可能赢B的最大分数。

输入描述

输入数据的第1个数字表示数字序列的长度N,后面紧跟着两个长度为N的数字序列。

输出描述

A可能赢B的最大分数

备注
  1. 这里要求计算A可能赢B的最大分数,不妨假设,A知道B的数字序列,且总是B先挑选数字并明示。
  2. 可以采用贪心策略,能赢的一定要赢,要输的尽量减少损失。
用例
输入3
4 8 10
3 6 4
输出3
说明

输入数据第1个数字表示数字序列长度为3,后面紧跟着两个长度为3的数字序列。

序列A:4 8 10

序列B:3 6 4

A可以赢的最大分数是3。获得该分数的比大小过程可以是:

1)A:4 B:3

2)A:8 B:6

3)A:10 B:4

题目解析

本题其实就是田忌赛马问题

JS算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); const lines = []; rl.on("line", (line) => { lines.push(line); if (lines.length == 3) { const n = parseInt(lines[0]); const a = lines[1].split(" ").map(Number); const b = lines[2].split(" ").map(Number); console.log(getResult(n, a, b)); lines.length = 0; } }); function getResult(n, a, b) { a.sort((a, b) => a - b); b.sort((a, b) => a - b); let la = 0; // 指向田忌最慢的马 let ra = n - 1; // 指向田忌最快的马 let lb = 0; // 指向齐王最慢的马 let rb = n - 1; // 指向齐王最快的马 let ans = 0; // 记录田忌获得银币数 while (la <= ra) { if (a[ra] > b[rb]) { // 田忌最快的马 比 齐王最快的马要快, 则直接比 ans += 1; ra--; rb--; } else if (a[ra] < b[rb]) { // 田忌最快的马 比 齐王最快的马要慢, 则结果肯定输, 为了保留田忌最快的马, 我们应该用田忌最慢的马去消耗掉齐王最快的马 ans -= 1; la++; rb--; } else { // 田忌最快的马 和 齐王最快的 速度相同, 此时如果平局的话,则会让田忌损失最快的马,因此我们应该找到田忌最慢的马, 即田忌必输的马来消耗掉齐王最快的马 if (a[la] > b[lb]) { // 如果田忌最慢的马 比 齐王最慢的马 快, 则此时田忌最慢的马不是必输的马 ans += 1; la++; lb++; } else { // 如果田忌最慢的马速度 <= 齐王最慢的马速度, 此时应该让田忌最慢的马 去消耗 齐王最快的马 // 如果齐王最快的马速度 > 田忌最慢的马速度,则田忌失去银币 // 如果齐王最快的马速度 == 田忌最慢的马速度,则田忌不失去银币 if (b[rb] > a[la]) ans -= 1; la++; rb--; } } } return ans; }
Java算法源码
import java.util.Arrays; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int n = Integer.parseInt(sc.nextLine()); int[] a = Arrays.stream(sc.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray(); int[] b = Arrays.stream(sc.nextLine().split(" ")).mapToInt(Integer::parseInt).toArray(); System.out.println(getResult(n, a, b)); } public static int getResult(int n, int[] a, int[] b) { Arrays.sort(a); Arrays.sort(b); int la = 0; // 指向田忌最慢的马 int ra = n - 1; // 指向田忌最快的马 int lb = 0; // 指向齐王最慢的马 int rb = n - 1; // 指向齐王最快的马 int ans = 0; // 记录田忌获得银币数 while (la <= ra) { if (a[ra] > b[rb]) { // 田忌最快的马 比 齐王最快的马要快, 则直接比 ans += 1; ra--; rb--; } else if (a[ra] < b[rb]) { // 田忌最快的马 比 齐王最快的马要慢, 则结果肯定输, 为了保留田忌最快的马, 我们应该用田忌最慢的马去消耗掉齐王最快的马 ans -= 1; la++; rb--; } else { // 田忌最快的马 和 齐王最快的 速度相同, 此时如果平局的话,则会让田忌损失最快的马,因此我们应该找到田忌最慢的马, 即田忌必输的马来消耗掉齐王最快的马 if (a[la] > b[lb]) { // 如果田忌最慢的马 比 齐王最慢的马 快, 则此时田忌最慢的马不是必输的马 ans += 1; la++; lb++; } else { // 如果田忌最慢的马速度 <= 齐王最慢的马速度, 此时应该让田忌最慢的马 去消耗 齐王最快的马 // 如果齐王最快的马速度 > 田忌最慢的马速度,则田忌失去银币 // 如果齐王最快的马速度 == 田忌最慢的马速度,则田忌不失去银币 if (b[rb] > a[la]) ans -= 1; la++; rb--; } } } return ans; } }
Python算法源码
# 输入获取 n = int(input()) a = list(map(int, input().split())) # 田忌的马速度数组 b = list(map(int, input().split())) # 齐王的马速度数组 # 算法入口 def getResult(): a.sort() b.sort() la = 0 # 指向田忌最慢的马 ra = n - 1 # 指向田忌最快的马 lb = 0 # 指向齐王最慢的马 rb = n - 1 # 指向齐王最快的马 ans = 0 # 记录田忌获得银币数 while la <= ra: if a[ra] > b[rb]: # 田忌最快的马 比 齐王最快的马要快, 则直接比 ans += 1 ra -= 1 rb -= 1 elif a[ra] < b[rb]: # 田忌最快的马 比 齐王最快的马要慢, 则结果肯定输, 为了保留田忌最快的马, 我们应该用田忌最慢的马去消耗掉齐王最快的马 ans -= 1 la += 1 rb -= 1 else: # 田忌最快的马 和 齐王最快的 速度相同, 此时如果平局的话,则会让田忌损失最快的马,因此我们应该找到田忌最慢的马, 即田忌必输的马来消耗掉齐王最快的马 if a[la] > b[lb]: # 如果田忌最慢的马 比 齐王最慢的马 快, 则此时田忌最慢的马不是必输的马 ans += 1 la += 1 lb += 1 else: # 如果田忌最慢的马速度 <= 齐王最慢的马速度, 此时应该让田忌最慢的马 去消耗 齐王最快的马 # 如果齐王最快的马速度 > 田忌最慢的马速度,则田忌失去银币 # 如果齐王最快的马速度 == 田忌最慢的马速度,则田忌不失去银币 if b[rb] > a[la]: ans -= 1 la += 1 rb -= 1 return ans # 算法调用 print(getResult())
C算法源码
#include <stdio.h> #include <stdlib.h> #define MAX_SIZE 100 int getResult(int n, int* a, int* b); int cmp(const void* a, const void* b); int main() { int n; scanf("%d", &n); int a[MAX_SIZE]; for(int i=0; i<n; i++) { scanf("%d", &a[i]); } int b[MAX_SIZE]; for(int i=0; i<n; i++) { scanf("%d", &b[i]); } printf("%d\n", getResult(n, a, b)); return 0; } int getResult(int n, int* a, int* b) { qsort(a, n, sizeof(int), cmp); qsort(b, n, sizeof(int), cmp); int la = 0; // 指向田忌最慢的马 int ra = n - 1; // 指向田忌最快的马 int lb = 0; // 指向齐王最慢的马 int rb = n - 1; // 指向齐王最快的马 int ans = 0; // 记录田忌获得银币数 while(la <= ra) { if(a[ra] > b[rb]) { // 田忌最快的马 比 齐王最快的马要快, 则直接比 ans += 1; ra--; rb--; } else if(a[ra] < b[rb]) { // 田忌最快的马 比 齐王最快的马要慢, 则结果肯定输, 为了保留田忌最快的马, 我们应该用田忌最慢的马去消耗掉齐王最快的马 ans -= 1; la++; rb--; } else { // 田忌最快的马 和 齐王最快的 速度相同, 此时如果平局的话,则会让田忌损失最快的马,因此我们应该找到田忌最慢的马, 即田忌必输的马来消耗掉齐王最快的马 if(a[la] > b[lb]) { // 如果田忌最慢的马 比 齐王最慢的马 快, 则此时田忌最慢的马不是必输的马 ans += 1; la++; lb++; } else { // 如果田忌最慢的马速度 <= 齐王最慢的马速度, 此时应该让田忌最慢的马 去消耗 齐王最快的马 // 如果齐王最快的马速度 > 田忌最慢的马速度,则田忌失去银币 // 如果齐王最快的马速度 == 田忌最慢的马速度,则田忌不失去银币 if(b[rb] > a[la]) { ans -= 1; } la++; rb--; } } } return ans; } int cmp(const void* a, const void* b) { return *((int*) a) - *((int*) b); }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/31 16:18:03

基于WebSocket实现实时图像生成:FLUX.1-dev模型前后端通信方案

基于WebSocket实现实时图像生成&#xff1a;FLUX.1-dev模型前后端通信方案 在AI内容生成日益普及的今天&#xff0c;用户不再满足于“输入提示词、等待结果”的静态交互模式。他们希望看到图像从模糊轮廓到细节丰富的演变过程——就像一位艺术家在画布上逐步勾勒作品。这种对“…

作者头像 李华
网站建设 2025/12/16 1:50:18

PyTorch安装与Qwen-Image部署全流程详解(附GPU优化技巧)

PyTorch安装与Qwen-Image部署全流程详解&#xff08;附GPU优化技巧&#xff09; 在生成式AI如火如荼的今天&#xff0c;图像创作已从“能否生成”转向“如何高效、稳定地生成高质量内容”。尤其在广告设计、数字艺术和电商配图等专业领域&#xff0c;用户不再满足于模糊或构图混…

作者头像 李华
网站建设 2026/1/8 23:11:34

浏览器串口助手终极指南:3分钟快速上手零安装串口调试

还在为复杂的串口调试工具安装而烦恼吗&#xff1f;波特律动串口助手作为一款创新的浏览器原生串口工具&#xff0c;让你告别繁琐的驱动配置&#xff0c;直接在浏览器中轻松管理串口设备&#xff01;无论是物联网开发、嵌入式调试还是蓝牙BLE连接&#xff0c;这款工具都能帮你快…

作者头像 李华
网站建设 2025/12/16 1:49:13

NPM Scripts集成LLama-Factory前端监控面板,实时查看训练状态

NPM Scripts集成LLama-Factory前端监控面板&#xff0c;实时查看训练状态 在大模型开发日益普及的今天&#xff0c;越来越多的团队和个人开发者希望快速微调一个属于自己的语言模型——无论是用于客服对话、内容生成&#xff0c;还是内部知识库问答。然而&#xff0c;传统训练流…

作者头像 李华