信息学奥赛复赛复习04-CSP-J2019-04-加工零件-位运算、整数映射0或1、结构体、初始化列表构造、动态数组、二维动态数组、队列、宽度优先搜索

news/2025/1/18 10:06:16/文章来源:https://www.cnblogs.com/myeln/p/18433846
PDF文档公众号回复关键字:20240926

1 2019 CSP-J 题目4 加工零件

[题目描述]

凯凯的工厂正在有条不紊地生产一种神奇的零件,神奇的零件的生产过程自然也很神奇。工厂里有 n位工人,工人们从 1∼n 编号。某些工人之间存在双向的零件传送带。保证每两名工人之间最多只存在一条传送带

如果 x号工人想生产一个被加工到第 L (L>1)阶段的零件,则所有与 x号工人有传送带直接相连的工人,都需要生产一个被加工到第 L−1 阶段的零件(但 x号工人自己无需生产第 L−1 阶段的零件)

如果 x 号工人想生产一个被加工到第 1 阶段的零件,则所有与 x 号工人有传送带直接相连的工人,都需要为 x 号工人提供一个原材料

轩轩是 1 号工人。现在给出 q张工单,第 i张工单表示编号为 ai的工人想生产一个第 Li 阶段的零件。轩轩想知道对于每张工单,他是否需要给别人提供原材料。他知道聪明的你一定可以帮他计算出来

[输入格式]

第一行三个正整数 n,m 和 q,分别表示工人的数目、传送带的数目和工单的数目

接下来 m行,每行两个正整数 u 和 v,表示编号为 u 和 v 的工人之间存在一条零件传输带。保证 u≠v

接下来 q 行,每行两个正整数 a 和 L,表示编号为 a 的工人想生产一个第 L 阶段的零件

[输出格式]

共 q 行,每行一个字符串 Yes 或者 No

如果按照第 i 张工单生产,需要编号为 1 的轩轩提供原材料,则在第 i 行输出 Yes;否则在第 i 行输出 No。注意输出不含引号

[输入输出样例]

输入 #1

3 2 6
1 2
2 3
1 1
2 1
3 1
1 2
2 2
3 2

输出 #1

No
Yes
No
Yes
No
Yes

输入 #2

5 5 5
1 2
2 3
3 4
4 5
1 5
1 1
1 2
1 3
1 4
1 5

输出 #2

No
Yes
No
Yes
Yes

说明/提示

样例 1 说明

编号为 1 的工人想生产第 1 阶段的零件,需要编号为 2 的工人提供原材料。

编号为 2 的工人想生产第 1 阶段的零件,需要编号为 1 和 3 的工人提供原材料。

编号为 3 的工人想生产第 1 阶段的零件,需要编号为 2 的工人提供原材料。

编号为 1 的工人想生产第 2 阶段的零件,需要编号为 2 的工人生产第 1 阶段的零 件,需要编号为 1 和 3 的工人提供原材料。

编号为 2 的工人想生产第 2 阶段的零件,需要编号为 1 和 3 的工人生产第 1 阶段的零件,他/她们都需要编号为 2 的工人提供原材料。

编号为 3 的工人想生产第 2 阶段的零件,需要编号为 2 的工人生产第 1 阶段的零件,需要编号为 1 和 3 的工人提供原材料

样例 2 说明

编号为 1 的工人想生产第 1 阶段的零件,需要编号为 2 和 5 的工人提供原材料。

编号为 1 的工人想生产第 2 阶段的零件,需要编号为 2 和 5 的工人生产第 1 阶段的零件,需要编号为 1,3,4 的工人提供原材料。

编号为 1 的工人想生产第 3 阶段的零件,需要编号为 2 和 5 的工人生产第 2 阶段的零件,需要编号为 1,3,4 的工人生产第 1 阶段的零件,需要编号为 2,3,4,5 的工人提供原材料。

编号为 1 的工人想生产第 4 阶段的零件,需要编号为 2 和 5 的工人生产第 3 阶段的零件,需要编号为 1,3,4 的工人生产第 2 阶段的零件,需要编号为 2,3,4,5 的工人生产第 1 阶段的零件,需要全部工人提供原材料。

编号为 1 的工人想生产第 5 阶段的零件,需要编号为 2 和 5 的工人生产第 4 阶段的零件,需要编号为 1,3,4 的工人生产第 3 阶段的零件,需要编号为 2,3,4,5 的工人生产第 2 阶段的零件,需要全部工人生产第 1 阶段的零件,需要全部工人提供原材料

2 相关知识点

1) 位运算

整数映射0或1

#include<bits/stdc++.h>
using namespace std;int n; 
/*对于整数n,进行如下操作 n&1,如果是偶数结果为0,如果为奇数结果为12&1=03&1=1 
*/
int main(){n=2;int op1 = n&1; cout<<"op1:"<<op1<<endl;n=3;int op2 = n&1;cout<<"op2:"<<op2<<endl;return 0;
}
/*
op1:0
op2:1
*/ 

2) 结构体

初始化列表构造

#include<bits/stdc++.h>
using namespace std;
/*C++提供了给成员变量初始化并赋值的方式,这就是初始化列表。在构造函数的()后,{}之前写,格式是冒号+成员名(初始值),对与自定义类型则是调用它的构造函数初始化
*/
struct xy{int x;int y;xy(int x,int y):x(x),y(y){}//初始化列表方式对成员变量进行初始化 
};int main(){xy xy1=xy(1,2);//通过构造函数传入参数给成员变量x,y cout<<xy1.x<<" "<<xy1.y;//输出成员变量x和y return 0;
}

3) 动态数组

#include<bits/stdc++.h>
using namespace std;vector<int> a(11,1);//声明数组a并赋值1 
vector<int> b(11);//声明数组a,默认赋值0 
int main(){a.push_back(2);//在a最后一个元素后面追加2 a.push_back(4);//在a最后一个元素后面追加4 for(int i=0;i<a.size();i++){//输出a数组中每个元素 cout <<a[i]<< ' ';}cout<<endl;for(int i=0;i<b.size();i++){//输出b数组中每个元素cout <<b[i]<< ' ';C++}return 0;
}
/*
输出
1 1 1 1 1 1 1 1 1 1 1 2 4
0 0 0 0 0 0 0 0 0 0 0 
*/

vector二维动态数组

#include<bits/stdc++.h>
using namespace std;
vector<int> v[2];//定义10行,每行是一个vector数组 
/*vector定义二维数组,行固定列可变示例定义2行,第1行2列,第2行3列 
*/
int main(){//第1行第1列放入2 v[0].push_back(2);//第1行第2列放入3 v[0].push_back(3);//第2行第1列放入4 v[1].push_back(4);//第2行第2列放入5v[1].push_back(5);//第2行第3列放入6 v[1].push_back(6);for(int i=0;i<=1;i++){for(int j=0;j<v[i].size();j++){cout<<v[i][j]<<" ";}cout<<endl;}return 0;
}
/*
2 3
4 5 6
*/

4) 队列

队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(head)进行删除操作,而在表的后端(tail)进行插入操作

队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头

队列可以理解成我们平时的排队,先进入的先出去

5) 宽度优先搜索 BFS

(BFS, Breadth First Search)是一个针对图和树的遍历算法。发明于上世纪50年代末60年代初,最初用于解决迷宫最短路径和网络路由等问题

是从根结点开始沿着树的宽度搜索遍历,将离根节点最近的节点先遍历出来,在继续深入遍历

实现DFS时,通常使用队列数据结构实现

3 思路分析

A工人,从0阶段到某一阶段,如下到2阶段,走2步可以提供原材料

A工人,从0阶段到某一阶段,如下到2阶段,走3步则不可以提供原材料

A工人,从0阶段到某一阶段,如下到2阶段,走4步则可以提供原材料(可以在1~2之间走2次)

由上可知,到偶数阶段零件,从原材料可以通过偶数步生产

A工人,从0阶段到某一阶段,如下到3阶段,走3步可以提供原材料

A工人,从0阶段到某一阶段,如下到3阶段,走4步则不可以提供原材料

A工人,从0阶段到某一阶段,如下到3阶段,走5步则可以提供原材料(可以在1~2之间走2次)

由上可知,到奇数阶段零件,从原材料可以通过奇数步生产

综上,上面问题可以转换成分2种情况求最短路问题

需要奇数步生产,求奇数步的最短路

需要偶数步生产,求偶数步最短路

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e5+10;
int n,m,q;//n表示工人数,m表示传送带数,q表示工单数 
vector<int> to[maxn];//定义vector数组,maxn个vector,存放传送带
/*从1号工人到当前编号工人的奇最短路或偶最短路dis[3][0] 表示1号工人到3号工人的偶最短路 dis[3][1] 表示1号工人到3号工人的奇最短路
*/
int dis[maxn][2]; 
struct node{//结构体 int id;//工人编号 int dis;//从1号工人到当前工人的距离 node(int a=0,int b=0):id(a),dis(b){};//初始化列表构造node 
};
queue<node> Q;//bfs使用队列 队列存储node结构体
/*通过bfs计算1号工人到其他工人的最短路如果到某工人距离是偶数,存储偶最短路 dis[i][0]如果到某工人距离是奇数,存储奇最短路 dis[i][1]
*/
void bfs(){for(int i=1;i<=n;i++){//初始化1号工人到所有工人奇偶最短路为-1,没有最短路 dis[i][0]=dis[i][1]=-1;}dis[1][0]=0;//从1号工人开始 Q.push(node(1,0));//1号工人放入队列 while(!Q.empty()){node now=Q.front();Q.pop();//取出队首 当前工人 int u=now.id;//当前工人编号 for(int i=0;i<to[u].size();i++){//和当前工人相邻的其他工人 int v=to[u][i];int x=now.dis+1;//当前距离+1 int op=x&1;//计算距离奇偶数 ,如果偶数为0,奇数为1 if(dis[v][op]!=-1) continue;//如果已经计算过距离,说明前面计算更短,不走此路 dis[v][op]=x;//计算最短路赋值 Q.push(node(v,x));//放入队列,计算此工人可连接工人的最短路 }}
}
int main(){scanf("%d%d%d",&n,&m,&q);//输入工人数 传送带数 工单数 for(int i=1,u,v;i<=m;i++){//输入对应的传送带 scanf("%d%d",&u,&v);to[u].push_back(v);to[v].push_back(u);}bfs();//宽搜计算1号工人到所有工人的奇偶最短路 存储到dis 数组 for(int i=1,a,L,op;i<=q;i++){//循环到dis数组中找对应的最短路 scanf("%d%d",&a,&L);//a号工人 生产L阶段零件 op=L&1;//判断L阶段的奇偶 偶数到dis[][0]找最短路,奇数到dis[][1]找最短路 if(dis[a][op]==-1) printf("No\n");//如果为-1没用最短路 无法提供原材料 else if(dis[a][op]>L) printf("No\n");//如果最短路大于L,无法达到,无法提供原材料 else printf("Yes\n");//其他可以提供原材料 }return 0;
}

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

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

相关文章

2024秋软件工程第一次结对作业

2024秋软件工程第一次结对作业之需求分析和原型设计 《构建之法》阅读成果 第3章 软件工程师的成长 这一章探讨了软件工程师在职业生涯中的成长路径,强调了不同阶段所需的技能和发展策略。以下是详细内容:初级工程师:技能要求:掌握基本的编程语言、开发工具和版本控制系统。…

人工智能下的GIS发展趋势

地理信息系统(GIS)与人工智能(AI)的结合正在开启智能地理信息时代的新篇章。随着AI技术的不断进步,GIS的应用前景变得更加广泛和深入,不仅在提高工作效率、提升分析精度方面展现出巨大潜力,还在促进资源共享、推动跨行业和跨领域协同发展方面发挥着重要作用。 数据采集与…

Flink-Yarn模式修改Task Slot的数量

1.修改 Flink 配置文件 (flink-conf.yaml) Flink 中的 TaskManager 是根据 slots 来分配任务的,默认情况下,一个 TaskManager 可以有多个 slots。你可以通过调整 flink-conf.yaml 中的以下配置来控制每个 TaskManager 的 slot 数量: taskmanager.numberOfTaskSlots: <num…

Linux服务器运维管理面板1Panel快速安装及安全配置

1Panel 是一个现代化、开源的 Linux 服务器运维管理面板,旨在帮助运维人员简化服务器管理任务。它提供了直观的界面和强大的功能,使用户可以通过图形化操作界面对服务器进行管理,减少了对命令行的依赖。1Panel 支持多种操作系统,适用于 Linux 服务器,提供了如网站管理、数…

怎么查看网站是否被谷歌收录,怎么查看网站是否被谷歌收录的办法

要查看网站是否被谷歌收录,可以采用以下几种办法: 一、使用谷歌搜索引擎的“site:”指令 这是最直接且常用的方法之一。具体步骤如下: 打开谷歌搜索引擎:在浏览器中打开Google.com,确保使用的是谷歌的官方搜索引擎。 输入查询指令:在搜索框中输入“site:”加上你的网站域…

【YashanDB知识库】YMP迁移oracle不兼容给用户授权高级包

本文转自YashanDB官网,具体内容请见https://www.yashandb.com/newsinfo/7441382.html?templateId=1718516 【标题】YMP迁移oracle不兼容给用户授权高级包 【关键字】oracle迁移,高级包授权 【问题描述】迁移评估任务中,oracle迁移YashanDB,YMP不兼容语句:grant execute o…

FICO:常规配置

FICO后台常规配置 定义mySAP系统中的国家: Tcode:OY01 SAP系统中的国家已经提前定义好了,无需自行配置,此处只做查看演示 检查货币代码 Tcode:OY03 SAP系统中的常规的货币代码也已经提前定义好了,一般不做更改此处只做查看演示为货币设置小数位数: Tcode:OY04 SAP系统中货币的小…

183天打造行业新标杆!BOE(京东方)国内首条第8.6代AMOLED生产线提前全面封顶

2024年9月25日,BOE(京东方)投建的国内首条第8.6代AMOLED生产线全面封顶仪式在成都市高新区举行,该生产线从开工到封顶仅用183天,以科学、高效、高质的速度再树行业新标杆。这不仅是BOE(京东方)创新突破、打造新质生产力的又一重大举措,也是OLED领域的里程碑事件,极大推…

按内容关键字批量查找文件并导出的方法

按内容关键字批量查找文件并导出的方法 文件批量查找复制导出 软件下载地址:http://6laohu.com 将指定目录下所有文件 按文件名中的关键字或文件内容中出现的关键字查找你需要的那些文件 并全部整理复制到指定文件夹下

Zotero 颜色标注

颜色列表:Orange(传说):该文章的核心Idea,通篇只有一两处的重点 Red(诅咒): 比较重要的idea,可以有多处; Magenta(史诗):非常巧妙的设计,学到了! Blue(稀有): 学习到知识点了。 ...... Grey(一般):没搞清楚的东西,查一下!

vulnhub 靶场DC-8实战指南

vulnhub 靶场DC-8实战指南 靶机下载地址:https://www.vulnhub.com/entry/dc-8,367/ 攻击机kali:192.168.48.138 靶机DC-8:192.168.48.171 信息收集查看靶机iparp-scan -l发现靶机ip为192.168.48.171端口扫描 nmap -A -p- -T4 192.168.48.171访问80端口的web站点随便点点,发…

JS中小数计算时获取正确结果

JS中,所有数字都以双精度64位浮点格式表示,因此部分小数进行计算时,会出现无法预测的长小数结果,导致无法得到想要的结果。为了避免这种现象出现,可以使用个简单方法转换后再进行计算,即将数字放大为整数后计算再等比缩小那关键就在于获取小数精度位,以下是方法代码:fu…