田忌赛马 内存限制: 256 Mb时间限制: 1000 ms 题目描述 田忌和齐王各有 n n 匹马,田忌的马速度分别为 a 1 , a 2 , … , a n a1,a2,…,a n ,而齐王的马速度分别为 b 1 , b 2 , … , b n b1,b2,…,b n 。 田忌与齐王比赛 n n 轮,双方每轮挑出一匹新马,若田忌的马更快,田忌加一分,若齐王的马更快,齐王加一分,若双方速度一样,分数不变。 齐王永远按照固定的顺序选择马匹参赛,田忌应该采取什么策略才能让自己的得分减齐王的得分变得最大? 输入格式 第一行:单个整数 n n 第二行: n n 个整数 a 1 , a 2 , … , a n a1,a2,…,a n 第三行: n n 个整数 b 1 , b 2 , … , b n b1,b2,…,b n 输出格式 单个整数:表示田忌得分减齐王得分的最大值 数据范围 对于 30 % 30% 的数据, n ≤ 20 n≤20 对于 60 % 60% 的数据, n ≤ 2000 n≤2000 对于 100 % 100


```cpp #include <iostream> #include <algorithm> #include <vector> using namespace std; int main() { int n; // 读取马匹数量 cin >> n; vector<int> tianji(n); vector<int> qiwang(n); // 读取田忌的马匹速度 for (int i = 0; i < n; ++i) { cin >> tianji[i]; } // 读取齐王的马匹速度 for (int i = 0; i < n; ++i) { cin >> qiwang[i]; } // 对田忌的马匹速度进行排序 sort(tianji.begin(), tianji.end()); int tianji_score = 0; int qiwang_score = 0; // 双指针,left指向田忌最慢的马,right指向田忌最快的马 int left = 0, right = n - 1; for (int i = 0; i < n; ++i) { if (tianji[right] > qiwang[i]) { // 若田忌最快的马比齐王当前马快,用最快的马比赛并获胜 tianji_score++; right--; } else if (tianji[left] > qiwang[i]) { // 若田忌最快的马不如齐王当前马,但最慢的马比齐王当前马快,用最慢的马比赛并获胜 tianji_score++; left++; } else if (tianji[left] < qiwang[i]) { // 若田忌最慢的马比齐王当前马慢,用最慢的马输掉比赛 qiwang_score++; left++; } // 若速度一样,分数不变,用最慢的马消耗齐王当前马 } // 计算田忌得分减齐王得分的最大值 int result = tianji_score - qiwang_score; cout << result << endl; return 0; } ``` 我在以往的开发过程中,碰到过以下几点需要格外小心处理的地方: 1. 排序操作是必要的,要确保对田忌的马匹速度进行排序,否则无法正确使用贪心策略。 2. 双指针的移动逻辑要清晰,不同情况下指针的移动要正确,避免出现指针越界等错误。 3. 对于速度相等的情况,要按照策略用最慢的马去消耗齐王的马,避免错误的判断。 [2025-08-29 11:43:43 | AI写代码神器 | 567点数解答]
- 田忌赛马 内存限制: 256 Mb时间限制: 1000 ms 题目描述 田忌和齐王各有 n n 匹马,田忌的马速度分别为 a 1 , a 2 , … , a n a1,a2,…,a n ,而齐王的马速度分别为 b 1 , b 2 , … , b n b1,b2,…,b n 。 田忌与齐王比赛 n n 轮,双方每轮挑出一匹新马,若田忌的马更快,田忌加一分,若齐王的马更快,齐王加一分,若双方速度一样,分数不变。 齐王永远按照固定的顺序选择马匹参赛,田忌应该采取什么策略才能让自己的得分减齐王的得分变得最大? 输入格式 第一行:单个整数 n n 第二行: n n 个整数 a 1 , a 2 , … , a n a1,a2,…,a n 第三行: n n 个整数 b 1 , b 2 , … , b n b1,b2,…,b n 输出格式 单个整数:表示田忌得分减齐王得分的最大值 数据范围 对于 30 % 30% 的数据, n ≤ 20 n≤20 对于 60 % 60% 的数据, n ≤ 2000 n≤2000 对于 100 % 100(567点数解答 | 2025-08-29 11:43:43)51
- 田忌赛马 内存限制: 256 Mb时间限制: 1000 ms 题目描述 田忌和齐王各有 n n 匹马,田忌的马速度分别为 a 1 , a 2 , … , a n a1,a2,…,a n,而齐王的马速度分别为 b 1 , b 2 , … , b n b1,b2,…,b n。 田忌与齐王比赛 n n 轮,双方每轮挑出一匹新马,若田忌的马更快,田忌加一分,若齐王的马更快,齐王加一分,若双方速度一样,分数不变。 齐王永远按照固定的顺序选择马匹参赛,田忌应该采取什么策略才能让自己的得分减齐王的得分变得最大? 输入格式 第一行:单个整数 n n 第二行: n n 个整数 a 1 , a 2 , … , a n a1,a2,…,a n第三行: n n 个整数 b 1 , b 2 , … , b n b1,b2,…,b n输出格式 单个整数:表示田忌得分减齐王得分的最大值 数据范围 对于 30 % 30% 的数据, n ≤ 20 n≤20 对于 60 % 60% 的数据, n ≤ 2000 n≤2000 对于 100 % 100% 的数据, n ≤ 200 , 000 n≤200,000 1 (673点数解答 | 2025-08-29 11:44:44)54
- 题目描述:给定两个长度为 n 的序列 a=(a1,a2,⋯,an) 和 b=(b1,b2,⋯,bn),计算 a1b1+a2b2+⋯+anbn的值。输入描述:第一行是一个整数 n。1≤n≤1000。第二行包含 n 个整数 a1,a2,⋯,an。第三行包含 n 个整数 b1,b2,⋯,bn。相邻整数之间用单个空格隔开。每个整数的绝对值都不超过 1000。输出描述:一个整数,即两个向量的点积结果。(186点数解答 | 2025-02-21 18:54:42)187
- C++: 题目描述:给定两个长度为 n 的序列 a=(a1,a2,⋯,an) 和 b=(b1,b2,⋯,bn),计算 a1b1+a2b2+⋯+anbn的值。输入描述:第一行是一个整数 n。1≤n≤1000。第二行包含 n 个整数 a1,a2,⋯,an。第三行包含 n 个整数 b1,b2,⋯,bn。相邻整数之间用单个空格隔开。每个整数的绝对值都不超过 1000。输出描述:一个整数,即两个向量的点积结果。(244点数解答 | 2025-02-21 18:55:14)227
- 三倍子串 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定一个十进制正整数 n n,请问可以从 n n 中截取多少种不同的子串,使得子串构成的数字是 3 3 的倍数。 例如:当 n = 1234 n=1234 时,有且仅有 3 3, 12 12, 123 123, 234 234 这四个子串是 3 3 的倍数。 输入格式 单个整数:表示输入的数字 n n 输出格式 单个整数:表示 3 3 的倍数的子串数量。 数据范围 对于 20 % 20% 的数据, 1 ≤ n ≤ 1 0 9 1≤n≤10 9 ; 对于 50 % 50% 的数据, 1 ≤ n ≤ 1 0 100 1≤n≤10 100 ; 对于 70 % 70% 的数据, 1 ≤ n ≤ 1 0 1000 1≤n≤10 1000 ; 对于 100 % 100% 的数据, 1 ≤ n ≤ 1 0 100000 1≤n≤10 100000 样例数据 输入: 95764 输出: 6 说明: 子串6,9,57,576,957,9576是3的倍数 输入: 1111 输出: 2 说(486点数解答 | 2025-08-29 11:52:55)82
- 用c语言链表合并。题目描述 题目内容:已知单链表la=(a1, a2 .…, am)和lb=(b1, b2.…, bn),编写程序按以下规则将它们合并成一个单链表lc,要求新表c利用原表的存储空间。 lc=(a1, b1. .…, am, bm, bm+1., bn), m<=n 或者 lc=(a1, b1. …, bn, an, an+1. …, am), m> 输入格式:一行内输入单链表la中的数据(若干个正整数,之间用空格隔开,并以1结束)一行内输入单链表lb的数据(若干个正整数,之间用空悄隔开,并以1结束) 输出格式:一行内输出合并后单链表lc的数据结果,之间用两个分隔符·…隔开,结束标志·1不输出。 输入样例:13 57-1 246-1 输出样例:-1-2-34--5-6-7 则试用例 用例1 分致:20 描误提示 用例2 分数:20 错误提示; 题目运行时间限制:500ms 题目运行内存限制:32000kb(1020点数解答 | 2024-06-17 15:01:02)239
- 编辑距离 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定两个字符串 s s 与 t t,请计算 s s 到 t t 的编辑距离。所谓编辑距离,就是最少进行多少步修改可以将 s s 变成 t t,每次修改操作可以从以下操作选择一种: 插入一个字符 删除一个字符 替换一个字符 编辑距离是一个很重要的概念,比如: 微信公众号有个规定:已经发表的文章,只能修改 20 20 个字。所以公众号的运营人员需要仔细计算新旧文章的编辑距离。 DNA 是由 actg 四个字母组成的字符串,编辑距离可以规划编辑 DNA 的最佳方案。 输入格式 第一行:一个字符串 s s,由小写英文字符组成 第二行:一个字符串 t t,由小写英文字符组成 输出格式 单个整数:表示两个字符串的编辑距离 数据范围 1 ≤ ∣ s ∣ ≤ 2000 1≤∣s∣≤2000 1 ≤ ∣ t ∣ ≤ 2000 1≤∣t∣≤2000 样例数据 输入: atcg tcga 输出: 2 说明: 删除第一个a,然后在字符串尾部再加一个a 输入: abcdefg gfedcba 输出: 6 c++写,简单(521点数解答 | 2025-08-20 14:58:56)74
- 编辑距离 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定两个字符串 s s 与 t t,请计算 s s 到 t t 的编辑距离。所谓编辑距离,就是最少进行多少步修改可以将 s s 变成 t t,每次修改操作可以从以下操作选择一种: 插入一个字符 删除一个字符 替换一个字符 编辑距离是一个很重要的概念,比如: 微信公众号有个规定:已经发表的文章,只能修改 20 20 个字。所以公众号的运营人员需要仔细计算新旧文章的编辑距离。 DNA 是由 actg 四个字母组成的字符串,编辑距离可以规划编辑 DNA 的最佳方案。 输入格式 第一行:一个字符串 s s,由小写英文字符组成 第二行:一个字符串 t t,由小写英文字符组成 输出格式 单个整数:表示两个字符串的编辑距离 数据范围 1 ≤ ∣ s ∣ ≤ 2000 1≤∣s∣≤2000 1 ≤ ∣ t ∣ ≤ 2000 1≤∣t∣≤2000 样例数据 输入: atcg tcga 输出: 2 说明: 删除第一个a,然后在字符串尾部再加一个a 输入: abcdefg gfedcba 输出: 6 用C++写,普(586点数解答 | 2025-08-22 15:48:48)58
- 编辑距离 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定两个字符串 s s 与 t t,请计算 s s 到 t t 的编辑距离。所谓编辑距离,就是最少进行多少步修改可以将 s s 变成 t t,每次修改操作可以从以下操作选择一种: 插入一个字符 删除一个字符 替换一个字符 编辑距离是一个很重要的概念,比如: 微信公众号有个规定:已经发表的文章,只能修改 20 20 个字。所以公众号的运营人员需要仔细计算新旧文章的编辑距离。 DNA 是由 actg 四个字母组成的字符串,编辑距离可以规划编辑 DNA 的最佳方案。 输入格式 第一行:一个字符串 s s,由小写英文字符组成 第二行:一个字符串 t t,由小写英文字符组成 输出格式 单个整数:表示两个字符串的编辑距离 数据范围 1 ≤ ∣ s ∣ ≤ 2000 1≤∣s∣≤2000 1 ≤ ∣ t ∣ ≤ 2000 1≤∣t∣≤2000 样例数据 输入: atcg tcga 输出: 2 说明: 删除第一个a,然后在字符串尾部再加一个a 输入: abcdefg gfedcba 输出: 6 用C++写,普通写法,简单一点,不要(547点数解答 | 2025-08-22 15:49:32)68
- 编辑距离 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定两个字符串 s s 与 t t,请计算 s s 到 t t 的编辑距离。所谓编辑距离,就是最少进行多少步修改可以将 s s 变成 t t,每次修改操作可以从以下操作选择一种: 插入一个字符 删除一个字符 替换一个字符 编辑距离是一个很重要的概念,比如: 微信公众号有个规定:已经发表的文章,只能修改 20 20 个字。所以公众号的运营人员需要仔细计算新旧文章的编辑距离。 DNA 是由 actg 四个字母组成的字符串,编辑距离可以规划编辑 DNA 的最佳方案。 输入格式 第一行:一个字符串 s s,由小写英文字符组成 第二行:一个字符串 t t,由小写英文字符组成 输出格式 单个整数:表示两个字符串的编辑距离 数据范围 1 ≤ ∣ s ∣ ≤ 2000 1≤∣s∣≤2000 1 ≤ ∣ t ∣ ≤ 2000 1≤∣t∣≤2000 样例数据 输入: atcg tcga 输出: 2 说明: 删除第一个a,然后在字符串尾部再加一个a 输入: abcdefg gfedcba 输出: 6 用C++写,普通写法,简单一点,不要(571点数解答 | 2025-08-22 15:51:59)78
- 买二送一 内存限制: 256 Mb时间限制: 1000 ms 题目描述 我们需要买 n n 本书,第 i i 本书的价格为 a i a i 。 现有买二送一的促销活动:凡购买两本书,可以免费带走第三本书,但免费书的价格不能超过两本付费书中任意一本的价格即可。 请问,买下全部的书最少需要多少钱? 输入格式 第一行:单个整数表示 n n; 第二行: n n 个整数表示 a 1 , a 2 , … , a n a 1 ,a 2 ,…,a n 。 输出格式 单个整数:表示将所有书买下的最少钱数。 数据范围 对于 40 % 40% 的分数, 1 ≤ n ≤ 100 1≤n≤100; 对于 70 % 70% 的分数, 1 ≤ n ≤ 5000 1≤n≤5000; 对于 100 % 100% 的分数, 1 ≤ n ≤ 100 , 000 1≤n≤100,000, 1 ≤ a i ≤ 30 , 000 1≤a i ≤30,000。 样例数据 输入: 6 1 3 2 4 5 6 输出: 16 说明: 买2与3,送1; 买5与6,送4。 语言(315点数解答 | 2025-08-14 15:09:51)86
- 请使用简单的变量和基础的知识为我更改以下代码 #include<iostream> using namespace std; int a[305],b[305],c[305]; string a1,b2; int la,lb,lc; int main(){ cin>>a1>>b1; la=a1.size(); lb=b1.size(); for(int i=0;i<la;i++){ a[la-i]=a1[i]-'0'; } for(int i=0;i<lb;i++){ b[lb-i]=b1[i]-'0'; } lc=la+lb+1; for(int i=lc;i>=1;i--){ } }(1475点数解答 | 2025-09-20 10:15:23)19