CCF 2017 09-02 公共钥匙盒
CCF 2017 09-02 公共钥匙盒
1.用快速排序函数结合排序规则函数来给取放排序。
2.vector数组的强大功能。
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
struct node{
int num;//钥匙的编号
int start;//动作开始时间
int action;//动作的类型 0:放 1:取
node(){
}
node(int num,int start,int action):num(num),start(start),action(action){
}
}; bool cmp(node a,node b)
{
if(a.start != b.start) return a.start<b.start;///1.按照动作开始时间升序排列
else{
///2.如果时间相同,则先放后取
if(a.action != b.action) return a.action < b.action;
else{
///3.如果时间相同且操作相同,则按照钥匙编号升序排队
return a.num<b.num;
}
}
} int main()
{
int n,k;
while(cin>>n>>k)
{
vector<node> V;
vector<int> state(n+);
for(int i=;i<=n;i++) state[i] = i;
for(int i=;i<k;i++)
{
int num,start,len;
cin>>num>>start>>len;
V.push_back(node(num,start,));//取走钥匙
V.push_back(node(num,start+len,));
} ///按照起始时间升序排列
sort(V.begin(),V.end(),cmp); for(int i=;i<V.size();i++)
{
node u = V[i];
if(u.action == )//取走钥匙操作
{
for(int i=;i<=n;i++)
if(state[i] == u.num)
{
state[i] = -;break;
}
}else{
for(int i=;i<=n;i++)
if(state[i] == -)
{
state[i] = u.num;break;
}
}
} for(int i=;i<=n;i++)
{
cout<<state[i];
if(i==n) cout<<endl;
else cout<<" ";
}
}
return ;
}

Python:
N, K = list(map(int, input().split()))
class node(object):
def __init__(self, num, time, action):
self.num, self.time, self.action = num, time, action
# action: 1代表取,0代表放 mlist = []
for i in range(K):
n1, n2, n3 = list(map(int, input().split()))
mlist.append(node(n1, n2, 1)) # 取
mlist.append(node(n1, n2 + n3, 0)) # 放 keyarr = [(i+1) for i in range(N)] # 将list进行排序,规则为
# 1. 按照时间升序
# 2. 时间相同,按照先放后取,即action升序
# 3. time和action相同,按照钥匙编号num升序
mlist.sort(key=lambda x:(x.time, x.action, x.num)) # 按照排序后的list进行操作
for i in range(2*K):
# print(mlist[i].time, mlist[i].action, mlist[i].num,)
if mlist[i].action == 1: # 取
keyarr[keyarr.index(mlist[i].num)] = -1
else:
for j in range(N):
if keyarr[j] == -1:
keyarr[j] = mlist[i].num
break for i in range(N):
print(keyarr[i], end="\t")

CCF 2017 09-02 公共钥匙盒的更多相关文章
- CCF CSP 201709-2 公共钥匙盒
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201709-2 公共钥匙盒 问题描述 有一个学校的老师共用N个教室,按照规定,所有的钥匙都必须 ...
- CCF 2017-09-2 公共钥匙盒
CCF 2017-09-2 公共钥匙盒 题目 问题描述 有一个学校的老师共用N个教室,按照规定,所有的钥匙都必须放在公共钥匙盒里,老师不能带钥匙回家.每次老师上课前,都从公共钥匙盒里找到自己上课的教室 ...
- CCF 201709-2公共钥匙盒
问题描述 有一个学校的老师共用N个教室,按照规定,所有的钥匙都必须放在公共钥匙盒里,老师不能带钥匙回家.每次老师上课前,都从公共钥匙盒里找到自己上课的教室的钥匙去开门,上完课后,再将钥匙放回到钥匙盒中 ...
- 公共钥匙盒(CCF)【模拟】
问题描述 有一个学校的老师共用N个教室,按照规定,所有的钥匙都必须放在公共钥匙盒里,老师不能带钥匙回家.每次老师上课前,都从公共钥匙盒里找到自己上课的教室的钥匙去开门,上完课后,再将钥匙放回到钥匙盒中 ...
- 公共钥匙盒 ccf
试题编号: 201709-2 试题名称: 公共钥匙盒 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 有一个学校的老师共用N个教室,按照规定,所有的钥匙都必须放在公共钥匙盒里, ...
- CCF(公共钥匙盒):思维+模拟
公共钥匙盒 201709-2 这题的思路一开始不是很清晰,一开始想用贪心去做.但是发现按照题目的思路不对.所以这里采用的是类似于多项式的加减的处理. #include<iostream> ...
- 调试大叔V1.0.1(2017.09.01)|http/s接口调试、数据分析程序员辅助开发神器
2017.09.01 - 调试大叔 V1.0.1*支持http/https协议的get/post调试与反馈:*可保存请求协议的记录:*内置一批动态参数,可应用于URL.页头.参数:*可自由管理cook ...
- csp公共钥匙盒
1.公共钥匙盒 问题描述 有一个学校的老师共用N个教室,按照规定,所有的钥匙都必须放在公共钥匙盒里,老师不能带钥匙回家.每次老师上课前,都从公共钥匙盒里找到自己上课的教室的钥匙去开门,上完课后,再将钥 ...
- ccf-201709-2 公共钥匙盒
问题描述 有一个学校的老师共用N个教室,按照规定,所有的钥匙都必须放在公共钥匙盒里,老师不能带钥匙回家.每次老师上课前,都从公共钥匙盒里找到自己上课的教室的钥匙去开门,上完课后,再将钥匙放回到钥匙盒中 ...
随机推荐
- 微信小程序登录获取手机号
一,发送请求携带 code 到后台换取 openid var that = this; wx.login({ success(res) { console.log(res); var code = r ...
- 关于写SQL语句的技巧
一.SQL总结写法 SQL的写法无非就是几种,关联查询,子查询,分组函数,各种函数的使用 1.首先根据要做的需求,先分析一下,需要用到哪些查询,例如要用到关联查询,就先把用到的表列出来,比如a,b,c ...
- 字节流、字符串、16进制字符串转换__java
package com.dvn.li.main; /** * @Package: * @ClassName:TypeConversion * @Description:字节流.字符串.16进制字符串转 ...
- Java Object对象中的wait,notify,notifyAll的理解
wait,notify,notifyAll 是定义在Object类的实例方法,用于控制线程状态,在线程协作时,大家都会用到notify()或者notifyAll()方法,其中wait与notify是j ...
- 在线预览word、excel文件
直接使用微软提供的在线预览服务. 免费 文件必须为网可访问地址,因为微软的服务器需要访问该文件
- openresty 阶段说明
开发中常用的7阶段 set_by_lua*: 流程分支处理判断变量初始化 rewrite_by_lua*: 转发.重定向.缓存等功能(例如特定请求代理到外网) access_by_lua*: IP 准 ...
- Python3+Appium学习笔记02-环境配置(下)
配置所需软件及我当前使用的版本: 1)java jdk 1.8.0 2)android sdk 24.4.1 3)Python3 3.7.3 4)Appium-Python-Client 5)n ...
- zprepass 之后再base pass为什么用equal不用lessequal
通常basepass深度测试用less equal 如果先做了zprepass 得到一张全屏depth 再画basepass的时候用equal这样 对于alphatest的物体 不需要再用alpha通 ...
- 18-SQLServer中给视图创建索引
一.注意点 1.索引视图所引用的基表必须在同一个数据库中,不是用union all引用多个数据库的表: 2.创建索引视图时要加上with schemabinding: 3.创建索引视图时要指定表所属的 ...
- k8s-应用部署
该demo主要作为一个dubbo项目通过maven自动化docker打包插件发布到镜像仓库样例工程.该wiki后面同时会提供k8s部署zk,mysql,应用包的整个过程.该项目大体功能:zk作为注册中 ...