攀拓(PAT)2024年春季 甲级题解

A-1 Braille Recognition

两层循环遍历,用数组计数

#include <bits/stdc++.h>
using namespace std;
int a[10];
int main() {int n,m;cin>>n>>m;string s[110];for(int i=0;i<n;i++)cin>>s[i];for(int i=0;i<n-2;i++) {for(int j=0;j<m-1;j++) {if(s[i][j]=='*'&&s[i][j+1]=='.'&&s[i+1][j]=='.'&&s[i+1][j+1]=='.'&&s[i+2][j]=='.'&&s[i+2][j+1]=='.')a[1]++;if(s[i][j]=='*'&&s[i][j+1]=='.'&&s[i+1][j]=='*'&&s[i+1][j+1]=='.'&&s[i+2][j]=='.'&&s[i+2][j+1]=='.')a[2]++;if(s[i][j]=='*'&&s[i][j+1]=='*'&&s[i+1][j]=='.'&&s[i+1][j+1]=='.'&&s[i+2][j]=='.'&&s[i+2][j+1]=='.')a[3]++;if(s[i][j]=='*'&&s[i][j+1]=='*'&&s[i+1][j]=='.'&&s[i+1][j+1]=='*'&&s[i+2][j]=='.'&&s[i+2][j+1]=='.')a[4]++;if(s[i][j]=='*'&&s[i][j+1]=='.'&&s[i+1][j]=='.'&&s[i+1][j+1]=='*'&&s[i+2][j]=='.'&&s[i+2][j+1]=='.')a[5]++;if(s[i][j]=='*'&&s[i][j+1]=='*'&&s[i+1][j]=='*'&&s[i+1][j+1]=='.'&&s[i+2][j]=='.'&&s[i+2][j+1]=='.')a[6]++;if(s[i][j]=='*'&&s[i][j+1]=='*'&&s[i+1][j]=='*'&&s[i+1][j+1]=='*'&&s[i+2][j]=='.'&&s[i+2][j+1]=='.')a[7]++;if(s[i][j]=='*'&&s[i][j+1]=='.'&&s[i+1][j]=='*'&&s[i+1][j+1]=='*'&&s[i+2][j]=='.'&&s[i+2][j+1]=='.')a[8]++;if(s[i][j]=='.'&&s[i][j+1]=='*'&&s[i+1][j]=='*'&&s[i+1][j+1]=='.'&&s[i+2][j]=='.'&&s[i+2][j+1]=='.')a[9]++;if(s[i][j]=='.'&&s[i][j+1]=='*'&&s[i+1][j]=='*'&&s[i+1][j+1]=='*'&&s[i+2][j]=='.'&&s[i+2][j+1]=='.')a[0]++;}}for(int i=1;i<=9;i++)cout<<a[i]<<" ";cout<<a[0];
}

A-2 AI Comments

对所有考生的每一个维度排序,取中位数
对于每组查询,判断准考证号存不存在,存在的话于中位数比较,把{{mi-vi, i}, i}加入map(根据key, value升序排序)

#include <bits/stdc++.h>
using namespace std;
map<string,int>s;vector<int>a[5],sa[5];
int main() {int n,m,av[5];cin>>n>>m;for(int i=0;i<n;i++) {string ss;cin>>ss;s[ss]=i;for(int j=0;j<5;j++) {int aa;cin>>aa;a[j].push_back(aa);}}for(int i=0;i<5;i++) {sa[i]=a[i];sort(sa[i].begin(),sa[i].end());av[i]=sa[i][n/2];}while(m--) {string ss;cin>>ss;if(s.find(ss)==s.end()) {cout<<"Not Found"<<endl;continue;}map<pair<int,int>,int>z,f;for(int i=0;i<5;i++) {if(a[i][s[ss]]>=av[i])z[{av[i]-a[i][s[ss]],i}]=i+1;else f[{av[i]-a[i][s[ss]],i}]=i+1;}for(auto it=z.begin();it!=z.end();it++) {if(it!=z.begin())cout<<" ";cout<<it->second;}if(!z.empty()&&!f.empty())cout<<" ";for(auto it=f.begin();it!=f.end();it++) {if(it!=f.begin())cout<<" ";cout<<"-"<<it->second;}cout<<endl;}
}

A-3 Degree of Skewness

深度优先搜索
后序遍历最后一个结点为根结点,在中序遍历序列中找到根节点的位置,然后判断有没有左右子树。

#include <bits/stdc++.h>
using namespace std;
int n,po[1010],in[1010],l,r;
void f(int pl,int pr,int il,int ir) {int p;for(int i=il;i<=ir;i++) {if(in[i]==po[pr])p=i;}if(p>il)f(pl,pl+p-il-1,il,p-1);if(p<ir)f(pl+p-il,pr-1,p+1,ir);if(p==il&&p!=ir)r++;if(p==ir&&p!=il)l++;
}
int main() {cin>>n;for(int i=1;i<=n;i++)cin>>po[i];for(int i=1;i<=n;i++)cin>>in[i];f(1,n,1,n);cout<<l-r<<" = "<<l<<" - "<<r;
}

A-4 Uniqueness of Topological Order

首先算出每个结点的入度,输出入度最小的结点输出,把入度为0的结点入队
①没有入度为0的点,不存在拓扑序列
之后广搜,搜索过的结点后继结点入度减一,入度为0则入队
②队列中结点不唯一,拓扑序列不唯一
③如果有结点没有入队,不存在拓扑序列

#include <bits/stdc++.h>
using namespace std;
vector<int>v[10010];
int in[10010],mi=999999,f,r=1/*是否存在拓扑序列*/,num/*加入拓扑序列的结点数*/;
vector<int>res;
int main() {int n,m,mi=999999;cin>>n>>m;while(m--) {int x,y;cin>>x>>y;v[x].push_back(y);in[y]++;}queue<int>q;for(int i=1;i<=n;i++) {if(in[i]==0)q.push(i); // 入度为0的结点入队mi=min(mi,in[i]); // 所有结点入度的最小值}for(int i=1;i<=n;i++) {if(in[i]==mi) { // 输出入度最小的结点if(f==1)cout<<" ";cout<<i;f=1;}}cout<<endl;if(mi!=0)r=0; // 1.没有入度为0的结点,不存在拓扑序列while(!q.empty()) {if(q.size()!=1) { // 2.拓扑序列不唯一r=0;break;}int t=q.front();q.pop();res.push_back(t); // 加入拓扑序列for(int i=0;i<v[t].size();i++) {in[v[t][i]]--; // 入度减一if(in[v[t][i]]==0) { // 为0则入队q.push(v[t][i]);}}num++; // 拓扑序列的结点}if(num!=n)r=0; // 3.如果有结点没在序列,不存在拓扑序列cout<<(r==1?"Yes":"No")<<endl;if(r==1) {cout<<res[0];for(int i=1;i<n;i++) {cout<<" "<<res[i];}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/740507.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

小迪安全39WEB 攻防-通用漏洞CSRFSSRF协议玩法内网探针漏洞利用

#知识点&#xff1a; 逻辑漏洞 1、CSRF-原理&危害&探针&利用等 2、SSRF-原理&危害&探针&利用等 3、CSRF&SSRF-黑盒下漏洞探针点 #详细点&#xff1a; CSRF 全称&#xff1a;Cross-site request forgery&#xff0c;即&#xff0c;跨站请求…

ThingsBoard开源物联网平台介绍

1. Thingsboard 简介 ThingsBoard是一个基于Java的开源物联网平台&#xff0c;旨在实现物联网项目的快速开发、管理和扩展。它使用行业标准的物联网协议&#xff08;MQTT、CoAP和HTTP&#xff09;实现设备连接&#xff0c;并支持云和本地部署。ThingsBoard结合了可扩展性、容错…

Springboot+vue的疫情居家办公系统(有报告)。Javaee项目,springboot vue前后端分离项目。

演示视频&#xff1a; Springbootvue的疫情居家办公系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot vue前后端分离项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09…

上海计算机学会 2023年11月月赛 丙组T5 推箱子(数学 思维 排序)

第五题&#xff1a;T5推箱子 标签&#xff1a;排序、数学、思维题意&#xff1a;给定 t t t组数据&#xff0c;每组数据给定长度为 n n n的字符串&#xff0c; 表示箱子&#xff0c; _ \_ _表示空格&#xff0c;求把箱子都推到一起&#xff08;即两两箱子之间没有空格&#…

Ubuntu18.04 安装搜狗输入法

一. 概述 自己的Ubuntu 18.04系统配置中文搜狗输入法&#xff0c;安装步骤&#xff0c;亲测可用 二. 安装步骤 2.1 确认系统版本和CPU架构 查看Ubuntu系统版本号&#xff0c;通过命令 lsb_release -a wuubuntume:~$ lsb_release -a No LSB modules are available. Distr…

安装Android Studio遇到Unable to access Android SDK add-on list的错误

第一次安装android studio的时候&#xff0c;提示&#xff1a;unable to access Android sdk add-on list 解决办法 这个错误一般是android studoi代理没有设置导致的&#xff0c;需要在setting里面设置&#xff1a; 点击Android Studio - Preferences&#xff0c;在 Appeara…

Linux中文件的权限

我们首先需要明白&#xff0c;权限 用户角色 文件的权限属性 一、拥有者、所属组和other&#xff08;用户角色&#xff09; 以文件file1为例 第一个箭头所指处即是文件的拥有者&#xff0c;拥有者为zz 第二个箭头所指处即使文件的所属组&#xff0c;所属组为zz 除去拥有者…

基于log4cpp封装日志类

一、log4cpp的使用 1. 下载log4cpp log4cpp官方下载地址 2. 安装log4cpp 第一步&#xff1a;解压 tar zxvf log4cpp-1.1.4.tar.gz 第二步&#xff1a;进入log4cpp文件夹并执行 ./configure tips&#xff1a;如果是ARM架构的CPU可能会失败&#xff0c;如下面这种情况&a…

Ubuntu查看ros版本-linux查看ros版本

使用ros带的rosversion命令即可查看自己的ros版本&#xff1a; rosversion -d

MATLAB算法实战应用案例精讲-【图像处理】边缘检测算子

目录 前言 数字图像处理基础知识与算法 1).数字图像 2).二值图像、灰度图像、彩色图像

如何在Windows中检测任何串行设备的COM端口?这里有一个应用程序

使用USB串行设备并不是最简单的工作流程。我们首先需要标识“设备管理器”下的COM端口,然后需要告诉应用程序使用该COM端口。 如果我们可以接收COM设备的自动通知,然后将它们配置为使用特定应用程序打开,该怎么办?Serial Port Notifier程序正是我们所需要的。 在最基本的级…

【Node.js从基础到高级运用】八、Express 框架入门

Express 框架入门 Express 是一个灵活且广泛使用的 Node.js web 应用框架&#xff0c;它提供了一系列强大特性来帮助开发者创建各种 Web 和移动设备应用。在这一节中&#xff0c;我们将介绍如何安装和配置 Express&#xff0c;并简单探讨其路由和中间件的概念。 安装 Express…

【计算机网络】UDP/TCP 协议

TCP 协议 一、传输层1. 再谈端口号2. 端口号范围划分3. 进程和端口号4. netstat5. pidof 二、UDP 协议1. UDP 协议端格式(报文)2. UDP 的特点3. 面向数据报4. UDP 的缓冲区 三、TCP 协议1. 认识 TCP2. TCP 协议段格式&#xff08;1&#xff09;4 位首部长度&#xff08;2&#…

爬蟲IP代理詳細指南

收集數據算是比較麻煩的任務&#xff0c;尤其是當數據量很大時。在網路抓取時暴露IP地址是常有的事&#xff0c;所以需要用到代理抓取工具&#xff0c;提供高效可靠的數據提取。 爬蟲IP代理抓取工具到底指什麼&#xff0c;以及如何在各種情況下使用它&#xff0c;比如說繞過地…

Spring Boot+Vue前后端分离项目如何部署到服务器

&#x1f31f; 前言 欢迎来到我的技术小宇宙&#xff01;&#x1f30c; 这里不仅是我记录技术点滴的后花园&#xff0c;也是我分享学习心得和项目经验的乐园。&#x1f4da; 无论你是技术小白还是资深大牛&#xff0c;这里总有一些内容能触动你的好奇心。&#x1f50d; &#x…

对话Shopify:平台工程如何帮助其自动化应对流量高峰

本文脱胎于 Obeservability Talk&#xff0c;完整内容请查看&#xff1a; https://www.youtube.com/watch?v6ShtsTTUizI 平台工程是近年来的热门话题。我们已经在 2023 年看到了开发人员们对它的追捧&#xff0c;预计在 2024 年后&#xff0c;我们也许会看到平台工程被广泛应用…

NVidia NX 中 ROS serial软件包的安装

自己装的ROS是noetic版本&#xff0c;受限于网络&#xff0c;直接用命令安装串口包不行。于是手动安装了一次。 1 下载源码 git clone https://github.com/wjwwood/serial.git 或者直接在浏览器里面输入 https://github.com/wjwwood/serial.git 2 解压 然后在serial&#xf…

OPC UA 服务器的Web访问

基于Web 的应用非常普及&#xff0c;例如基于web 的SCADA &#xff0c;物联网 Dashboard 等等&#xff0c;那么基于Web 的应用如何访问OPC UA 服务器呢&#xff1f;本博文讨论这方面的问题。 Web 的通信方式 Web 是我们通常讲的网站&#xff0c;它由浏览器&#xff0c;HTTP 服…

sqllab第二关通关笔记

知识点整理&#xff1a; 数值型注入判断手法 1/1 1/0 回显不同错误注入函数 extractvalue(xml_flag,xpath) xml_flag&#xff1a;文件表示符xpath&#xff1a;文件路径&#xff1b;不能识别‘~’ ‘#’ 等特殊字符&#xff1b;遇到就报错并打印xpath内容~(十六进制表示)&#…

架构师之路:中台和微服务区别

什么是中台架构&#xff1f; 中台架构是一种将业务逻辑和技术能力模块化的架构思想&#xff0c;通过构建统一的中间层服务&#xff0c;将业务能力和技术能力解耦&#xff0c;使得各业务领域的功能和服务能够共享和复用。中台包括业务中台和技术中台两个方面&#xff1a; 业务…