PAT(乙级)2020年秋季考试
比赛链接:https://pintia.cn/market/item/1302816969611366400
7-1 多二了一点 (15分)
题解
模拟。
代码
#include <bits/stdc++.h>
using namespace std; int sum(string s) {
int res = 0;
for (char c : s) res += c - '0';
return res;
} int main() {
string s;
cin >> s;
if (s.size() & 1) {
cout << "Error: " << s.size() << " digit(s)" << "\n";
} else {
string s_x = s.substr(s.size() / 2);
string s_y = s.substr(0, s.size() / 2);
if (sum(s_x) - sum(s_y) == 2)
cout << "Yes: " << s_x << " - " << s_y << " = 2" << "\n";
else
cout << "No: " << s_x << " - " << s_y << " != 2" << "\n";
}
}
7-2 数字之王 (20分)
题解
模拟。
代码
#include <bits/stdc++.h>
using namespace std; int func(int n) {
if (n == 0) return 0;
int mul = 1;
while (n) {
int x = n % 10;
mul *= x * x * x;
n /= 10;
}
int res = 0;
while (mul) {
res += mul % 10;
mul /= 10;
}
return res;
} int main() {
int N1, N2;
cin >> N1 >> N2;
vector<int> a(N2 - N1 + 1);
iota(a.begin(), a.end(), N1);
while (any_of(a.begin(), a.end(), [](int x) { return x >= 10; })) {
for (auto &x : a)
x = func(x);
}
int mx = 0;
map<int, int> cnt;
for (auto x : a) {
if (++cnt[x] > mx)
mx = cnt[x];
}
vector<int> ans;
for (auto i : cnt) {
if (i.second == mx)
ans.push_back(i.first);
}
sort(ans.begin(), ans.end());
cout << mx << "\n";
for (int i = 0; i < ans.size(); i++)
cout << ans[i] << " \n"[i == ans.size() - 1];
}
7-3 如需挪车请致电 (20分)
题解
有点麻烦的模拟。
代码
#include <bits/stdc++.h>
using namespace std; map<string, int> mp{
{"ling", 0},
{"yi", 1},
{"er", 2},
{"san", 3},
{"si", 4},
{"wu", 5},
{"liu", 6},
{"qi", 7},
{"ba", 8},
{"jiu", 9}
}; int to_int(string s) {
if (mp.count(s)) {
return mp[s];
} else {
int res = 0;
for (int i = 0; i < int(s.size()); i++)
res = res * 10 + s[i] - '0';
return res;
}
} int func(string s) {
if (s.find("sqrt") != string::npos) {
return sqrt(to_int(s.substr(4)));
}
for (char oper : string("+-*/%^")) {
int oper_pos = s.find(oper);
if (oper_pos != string::npos) {
int a = to_int(s.substr(0, oper_pos));
int b = to_int(s.substr(oper_pos + 1));
if (oper == '+') return a + b;
if (oper == '-') return a - b;
if (oper == '*') return a * b;
if (oper == '/') return a / b;
if (oper == '%') return a % b;
if (oper == '^') return pow(a, b);
}
}
return to_int(s);
} int main() {
for (int i = 0; i < 11; i++) {
string s;
cin >> s;
cout << func(s);
}
}
7-4 胖达与盆盆奶 (20分)
题解
将熊猫的编号视作横坐标,体重视作纵坐标,将纵坐标相连即得一条凹凸的曲线,每次从曲线的凹处向两边延伸,两个凹处的相接点取较大值。
代码
#include <bits/stdc++.h>
using namespace std;
int main() {
int n;
cin >> n;
vector<int> a(n);
for (int i = 0; i < n; i++)
cin >> a[i];
vector<int> p(n);
iota(p.begin(), p.end(), 0);
sort(p.begin(), p.end(), [&](int x, int y) {
return a[x] < a[y];
});
vector<int> milk(n);
vector<bool> vis(n);
for (auto i : p) {
if (vis[i]) continue;
milk[i] = 200;
vis[i] = true;
for (int j = i - 1; j >= 0 and a[j] >= a[j + 1]; j--) {
milk[j] = max(milk[j], milk[j + 1] + (a[j] > a[j + 1] ? 100 : 0));
vis[j] = true;
}
for (int j = i + 1; j < n and a[j] >= a[j - 1]; j++) {
milk[j] = max(milk[j], milk[j - 1] + (a[j] > a[j - 1] ? 100 : 0));
vis[j] = true;
}
}
cout << accumulate(milk.begin(), milk.end(), 0) << "\n";
}
7-5 买地攻略 (25分)
题解一
$O_{(n^2)}$,枚举区间的左右端点,但理论上来讲应该过不了。
代码
#include <bits/stdc++.h>
using namespace std;
int main() {
int n, m;
cin >> n >> m;
vector<int> a(n);
for (int i = 0; i < n; i++)
cin >> a[i];
int ans = 0;
for (int i = 0; i < n; i++) {
int sum = 0;
for (int j = i; j < n; j++) {
sum += a[j];
if (sum <= m) ++ans;
}
}
cout << ans << "\n";
}
题解二
$O_{(nlog_n)}$,枚举区间左端点,利用前缀和二分查找右端点。
代码
#include <bits/stdc++.h>
using namespace std;
int main() {
int n, m;
cin >> n >> m;
vector<int> a(n);
for (int i = 0; i < n; i++)
cin >> a[i];
vector<int> pre(n);
for (int i = 0; i < n; i++) {
if (i == 0) pre[i] = a[i];
else pre[i] = pre[i - 1] + a[i];
}
int ans = 0;
for (int i = 0; i < n; i++) {
int j = upper_bound(pre.begin(), pre.end(), (i == 0 ? 0 : pre[i - 1]) + m) - pre.begin();
ans += j - i;
}
cout << ans << "\n";
}
PAT(乙级)2020年秋季考试的更多相关文章
- PAT(甲级)2017年秋季考试
PAT(甲级)2017年秋季考试 D题红黑树待补21/30 大佬的代码,看着想哭,这才是艺术啊 A Cut Integer 模拟题 #include<bits/stdc++.h> usin ...
- PAT乙级:1094 谷歌的招聘 (20分)
PAT乙级:1094 谷歌的招聘 (20分) 题干 2004 年 7 月,谷歌在硅谷的 101 号公路边竖立了一块巨大的广告牌(如下图)用于招聘.内容超级简单,就是一个以 .com 结尾的网址,而前面 ...
- PAT乙级:1088 三人行 (20分)
PAT乙级:1088 三人行 (20分) 题干 子曰:"三人行,必有我师焉.择其善者而从之,其不善者而改之." 本题给定甲.乙.丙三个人的能力值关系为:甲的能力值确定是 2 位正整 ...
- PAT乙级:1072开学寄语(20分)
PAT乙级:1072开学寄语(20分) 题干 下图是上海某校的新学期开学寄语:天将降大任于斯人也,必先删其微博,卸其 QQ,封其电脑,夺其手机,收其 ipad,断其 wifi,使其百无聊赖,然后,净面 ...
- PAT乙级:1090危险品装箱(25分)
PAT乙级:1090危险品装箱(25分) 题干 集装箱运输货物时,我们必须特别小心,不能把不相容的货物装在一只箱子里.比如氧化剂绝对不能跟易燃液体同箱,否则很容易造成爆炸. 本题给定一张不相容物品的清 ...
- PAT乙级:1053 住房空置率 (20分)
PAT乙级:1053 住房空置率 (20分) 题干 在不打扰居民的前提下,统计住房空置率的一种方法是根据每户用电量的连续变化规律进行判断.判断方法如下: 在观察期内,若存在超过一半的日子用电量低于某给 ...
- PAT乙级:1057 数零壹 (20分)
PAT乙级:1057 数零壹 (20分) 题干 给定一串长度不超过 105 的字符串,本题要求你将其中所有英文字母的序号(字母 a-z 对应序号 1-26,不分大小写)相加,得到整数 N,然后再分析一 ...
- PAT乙级:1069 微博转发抽奖 (20分)
PAT乙级:1069 微博转发抽奖 (20分) 题干 小明 PAT 考了满分,高兴之余决定发起微博转发抽奖活动,从转发的网友中按顺序每隔 N 个人就发出一个红包.请你编写程序帮助他确定中奖名单. 输入 ...
- PAT乙级:1092 最好吃的月饼 (20分)
PAT乙级:1092 最好吃的月饼 (20分) 题干 月饼是久负盛名的中国传统糕点之一,自唐朝以来,已经发展出几百品种. 若想评比出一种"最好吃"的月饼,那势必在吃货界引发一场腥风 ...
随机推荐
- [Leetcode刷题]——链表
一.找出两个链表的交点 160.相交链表(easy)2021-01-05 编写一个程序,找到两个单链表相交的起始节点 如下面的两个链表,在c1 处相交: public class Soluti ...
- C语言的类型大小
C语言的类型大小 设计程序的时候我们一般会考虑的尽量的周全,尤其是像C这样的静态类型语言. 有一些溢出的问题就源于没有搞清楚变量的大小范围,所以我们编写的时候需要特别注意 C的整形(整数类型)大小 C ...
- 了解一下RPC,为何诞生RPC,和HTTP有什么不同?
了解一下RPC,为何诞生RPC,和HTTP有什么不同? 开篇提问 什么是RPC? 为什么需要RPC,用来解决什么问题? RPC与HTTP有什么不同? 你知道几种RPC? 认识RPC RPC:Remot ...
- 【JavaWeb】i18n 国际化
i18n 国际化 什么是 i18n 国际化(Internationalization)指的是同一个网站可以支持多种不同的语言,以方便不同国家,不同语种的用户访问. 希望相同的一个网站,不同人访问的时候 ...
- 美业黑科技 ▏肌肤管家SkinRun V3S智能肌肤测试仪,实现“护肤”私人定制
肌肤如同身体,也需要定时的"健康检查",但仅凭肉眼难以窥见深层的肌肤问题.而现在,肌肤管家SkinRun前沿黑科技护肤测试仪--SkinRun V3S便能帮助用户对症下药.肌肤管家 ...
- 【Zabbix】配置zabbix agent向多个server发送数据
1.背景: server端: 172.16.59.197 ,172.16.59.98 agent 端: hostname:dba-test-hzj02 IP:172.16.59.98 2.方式: 配 ...
- 【Linux】postfix大坑笔记
由于需要,想弄一个自动发送邮件的mailx或者sendmail 但是执行 echo "test" | mail -s "Worning mail !" xxxx ...
- 爬虫学习(二)requests模块的使用
一.requests的概述 requests模块是用于发送网络请求,返回响应数据.底层实现是urllib,而且简单易用,在python2.python3中通用,能够自动帮助我们解压(gzip压缩的等) ...
- 转 Fiddler5 发送HTTP请求
Fiddler5 发送HTTP请求 文章转自:https://www.cnblogs.com/zhengna/p/10879573.html 1.Fiddler Composer发送HTTP请求 C ...
- 《UML与设计原则》--第四小组
关于设计模式与原则 一.设计模式简介 设计模式描述了软件设计过程中某一类常见问题的一般性的解决方案.而面向对象设计模式描述了面向对象设计过程中特定场景下.类与相互通信的对象之间常见的组织关系. 二.G ...