CCF/CSP 201709-2公共钥匙盒100分
创始人
2024-05-29 02:26:37
0

试题编号:

201709-2

试题名称:

公共钥匙盒

时间限制:

1.0s

内存限制:

256.0MB

问题描述:

问题描述

  有一个学校的老师共用N个教室,按照规定,所有的钥匙都必须放在公共钥匙盒里,老师不能带钥匙回家。每次老师上课前,都从公共钥匙盒里找到自己上课的教室的钥匙去开门,上完课后,再将钥匙放回到钥匙盒中。

  钥匙盒一共有N个挂钩,从左到右排成一排,用来挂N个教室的钥匙。一串钥匙没有固定的悬挂位置,但钥匙上有标识,所以老师们不会弄混钥匙。

  每次取钥匙的时候,老师们都会找到自己所需要的钥匙将其取走,而不会移动其他钥匙。每次还钥匙的时候,还钥匙的老师会找到最左边的空的挂钩,将钥匙挂在这个挂钩上。如果有多位老师还钥匙,则他们按钥匙编号从小到大的顺序还。如果同一时刻既有老师还钥匙又有老师取钥匙,则老师们会先将钥匙全还回去再取出。

  今天开始的时候钥匙是按编号从小到大的顺序放在钥匙盒里的。有K位老师要上课,给出每位老师所需要的钥匙、开始上课的时间和上课的时长,假设下课时间就是还钥匙时间,请问最终钥匙盒里面钥匙的顺序是怎样的?

输入格式

  输入的第一行包含两个整数N, K。

  接下来K行,每行三个整数w, s, c,分别表示一位老师要使用的钥匙编号、开始上课的时间和上课的时长。可能有多位老师使用同一把钥匙,但是老师使用钥匙的时间不会重叠。

  保证输入数据满足输入格式,你不用检查数据合法性。

输出格式

  输出一行,包含N个整数,相邻整数间用一个空格分隔,依次表示每个挂钩上挂的钥匙编号。

样例输入

5 2

4 3 3

2 2 7

样例输出

1 4 3 2 5

样例说明

  第一位老师从时刻3开始使用4号教室的钥匙,使用3单位时间,所以在时刻6还钥匙。第二位老师从时刻2开始使用钥匙,使用7单位时间,所以在时刻9还钥匙。

  每个关键时刻后的钥匙状态如下(X表示空):

  时刻2后为1X345;

  时刻3后为1X3X5;

  时刻6后为143X5;

  时刻9后为14325。

样例输入

5 7

1 1 14

3 3 12

1 15 12

2 7 20

3 18 12

4 21 19

5 30 9

样例输出

1 2 3 5 4

评测用例规模与约定

  对于30%的评测用例,1 ≤ N, K ≤ 10, 1 ≤ w ≤ N, 1 ≤ s, c ≤ 30;

  对于60%的评测用例,1 ≤ N, K ≤ 50,1 ≤ w ≤ N,1 ≤ s ≤ 300,1 ≤ c ≤ 50;

  对于所有评测用例,1 ≤ N, K ≤ 1000,1 ≤ w ≤ N,1 ≤ s ≤ 10000,1 ≤ c ≤ 100。

n,k=map(int,input().split())
l=[]
key=[i for i in range(1,n+1)]for i in range(k):l.append([int(i) for i in input().split()])
lz={}
for i in range(1,15000):lz[i]=[]
for i in range(k):l[i][2]=l[i][2]+l[i][1]for j in range(2):if j==0:lz[l[i][1]].append([0,l[i][0]])#0代表借else:lz[l[i][2]].append([-1,l[i][0]])#-1代表还# 上面都是数据处理,把数据变为{1:[[0,1],[0,2]],2:[[-1,2],[0,3]]}这样的形式,
#键对应时间,值为要处理的事件:0表示借,-1表示还,后面是借、还的钥匙号,
# 这样排序就会把还放在借的前面,因为-1比0小,如果第一个参数相同,
#排序也会把第二个参数从小到大排,
# 这样就满足:如果有多位老师还钥匙,则他们按钥匙编号从小到大的顺序还。
#如果同一时刻既有老师还钥匙又有老师取钥匙,则老师们会先将钥匙全还回去再取出。# 这样按照时间从小到大处理
#
for i in lz:if lz[i]!=[]:# print(lz[i])for j in sorted(lz[i]):#上面说的排序if j[0]==0:# print(j[1])key[key.index(j[1])]=0#借就把钥匙的位置变为0else:key[key.index(0)]=j[1]#还就找第一个0的位置,实现从左往右还# print(key)for i in key:print(i,end=' ')
# print(lz)

相关内容

热门资讯

上海公安机关圆满完成五一假期安... 转自:上观新闻5月1日至5日,上海公安机关精心组织、周密部署,全面加强道路交通组织、大客流疏导、隐患...
宁波保时捷撞摩托第一时间不救人... 【#宁波保时捷撞摩托第一时间不救人先换车牌#,警方通报:男子涉嫌危险驾驶被刑拘】#警方通报撞摩托保时...
论文出现“男性确诊子宫肌瘤” ... 转自:中国宁波网山东大学齐鲁医院官方微博5月5日发布情况说明:5月5日上午,我院关注到网友反馈的相关...
粉色预警!杭州全面清理福寿螺卵... 来源:杭州日报 最近,在浙江多条河道边散步时,你有没有注意到一串串粉红色的“葡萄”?这些可不是新奇植...
东威科技高管李阳照拟减持200... 5月5日,东威科技公告,副总经理、非独立董事李阳照计划在2025年5月27日至2025年8月26日期...
“五一”微度假撒欢!消费热浪嗨... 转自:中国体育报“五一”假期旅游市场呈现别样盛景,“微度假”当仁不让成为主角。“微”是指时间投入少,...
4月逾170家科创板公司获机构... 《科创板日报》5月5日讯(记者 黄修眉) 随着上市公司陆续披露2024年报与2025年一季报,市场迎...
《哪吒2》总票房破158亿 即... 转自:央视新闻客户端据网络平台数据,截至5月5日,电影《哪吒之魔童闹海》总票房(包含港澳台和海外票房...
南极生物在黑暗季节如何生存?第... 磷虾拖网大丰收探索南极生物如何生存近日,中国第41次南极考察科考队员在南极罗斯海进行了首个秋冬联合航...
“五一”假期昆明机场口岸出入境... 中新网昆明5月5日电 (陈志蓉)“五一”假期,昆明长水国际机场出入境客流持续走高。5月1日0时至5月...
巴菲特将继续担任伯克希尔公司董...   当副董事长格雷格・阿贝尔在 2026 年初接任首席执行官一职时,亿万富翁沃伦・巴菲特将继续担任伯...
齐鲁医院论文涉学术不端,期刊及... 医院证实论文存在学术不端问题,医院及期刊都应当采取撤稿、追责等措施,以维护学术公信力。齐鲁医院作为作...
"即买即退"... 离境退税“即买即退”服务措施正从多地试点推广至全国,作为上海国际消费中心城市核心承载区,黄浦区已有5...
以军轰炸加沙地带南部汗尤尼斯一... △汗尤尼斯(资料图)总台记者5日获悉,以军当天轰炸了加沙地带南部汗尤尼斯地区的一处住宅,目前已致5人...
宏微科技股东常州宏众咨询管理合... 5月5日,宏微科技(维权)公告,股东常州宏众咨询管理合伙企业(有限合伙)计划在2025年5月12日至...
突发!台湾花莲县海域5.7级地... 据中国地震台网正式测定,5月5日18时53分在台湾花莲县海域发生5.7级地震,震源深度15公里,震中...
雷寨小学荣获未央区教育系统20... 阳光讯(记者 刘杰)在全体师生的共同努力与拼搏下,西安市未央区雷寨小学在2024 年度考核中脱颖而出...
2024年上市公司薪酬榜出炉 ... 随着2024年上市公司年报披露正式收官,上市公司高管薪酬、人均薪酬也随之成为关注焦点。同花顺iFin...
冠石科技高管王顺利拟减持9.3... 5月5日,冠石科技公告,副总经理、非独立董事、董事会秘书王顺利计划在2025年5月27日至2025年...
能开黑上分扮COSER,也有亲... 年轻人爱上一台车的方式,不再是驾校教练的种草,更不是各种传统汽车广告。这种改变也让各大汽车厂商苦恼,...