解释代码: Gst, Ged = -1e9, -1e9 # Global start, Global end sections.sort() merged_sections = [] for st, ed in sections: if Ged < st: if Gst != -1e9: merged_sections.append([Gst, Ged]) Gst, Ged = st, ed else: Ged = max(Ged, ed) if Gst != -1e9: merged_sections.append([Gst, Ged])
时间: 2024-02-10 13:23:48 浏览: 76
这段代码的作用是合并一组区间,将重叠的区间合并为一个更大的区间。
首先,代码初始化了两个全局变量 Gst 和 Ged,分别表示全局的起始和结束位置,初始值为 -1e9(即负无穷大)。
然后,代码对输入的区间列表 sections 进行排序。
接下来,使用一个循环遍历每个区间 (st, ed)。如果当前区间的起始位置 st 大于全局结束位置 Ged,则说明当前区间与之前的区间没有重叠,需要将之前的区间添加到 merged_sections 中,并更新全局起始位置 Gst 和结束位置 Ged 为当前区间的起始位置 st 和结束位置 ed。如果当前区间与之前的区间有重叠,则更新全局结束位置 Ged 为当前区间的结束位置 ed。
最后,如果全局起始位置 Gst 不等于初始值 -1e9,则说明最后一个区间还没有添加到 merged_sections 中,需要将其添加到 merged_sections 中。
最终,merged_sections 中存储了合并后的区间列表。
相关问题
在对gst-plugins-base-1.16.0进行make的时候出现错误:make[2]: 进入目录“/home/cxh/geo_-work-project-g-master/Project_MIS/Project_Camera/Project_Push/Gstreamer_A7/gst-plugins-base-1.16.0/tools” CCLD gst-device-monitor-1.0 /work/imx/meta-toolchain/sysroots/x86_64-fslcsdk-linux/usr/libexec/arm-fslc-linux-gnueabi/gcc/arm-fslc-linux-gnueabi/7.2.0/real-ld: warning: libz.so.1, needed by ../gst-libs/gst/tag/.libs/libgsttag-1.0.so, not found (try using -rpath or -rpath-link) ../gst-libs/gst/tag/.libs/libgsttag-1.0.so: undefined reference to `uncompress' collect2: error: ld returned 1 exit status make[2]: *** [Makefile:734:gst-device-monitor-1.0] 错误 1 make[2]: 离开目录“/home/cxh/geo_-work-project-g-master/Project_MIS/Project_Camera/Project_Push/Gstreamer_A7/gst-plugins-base-1.16.0/tools” make[1]: *** [Makefile:731:all-recursive] 错误 1 make[1]: 离开目录“/home/cxh/geo_-work-project-g-master/Project_MIS/Project_Camera/Project_Push/Gstreamer_A7/gst-plugins-base-1.16.0” make: *** [Makefile:662:all] 错误 2
这个错误提示是因为链接时找不到 libz 库文件导致的。您可以尝试通过以下步骤解决:
1. 确认您的系统中是否已经安装了 libz 库文件。如果没有安装,请先安装 libz 库文件。
2. 如果已经安装了 libz 库文件,可以尝试通过设置 LD_LIBRARY_PATH 环境变量来指定库文件的搜索路径。具体方法是在终端中输入以下命令:
export LD_LIBRARY_PATH=/usr/lib:/usr/local/lib
3. 如果仍然无法解决问题,可以尝试在编译时添加 -L 和 -l 选项来指定库文件的搜索路径和库文件名。具体方法是在编译命令中添加以下选项:
-L/path/to/libz -lz
其中,/path/to/libz 是 libz 库文件所在的路径,-lz 表示链接 libz 库文件。
希望这些方法能够帮助您解决问题。
DELIMITER $$ CREATE /*[DEFINER = { user | CURRENT_USER }]*/ PROCEDURE `qy_task`.`peopletask`(IN job VARCHAR(200),IN seriesid VARCHAR(200),IN classid VARCHAR(200),IN prodid VARCHAR(200),IN cycleid VARCHAR(200) ) /*LANGUAGE SQL | [NOT] DETERMINISTIC | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA } | SQL SECURITY { DEFINER | INVOKER } | COMMENT 'string'*/ BEGIN #把表围绕id创建一边然后再关联输出数据 CREATE TEMPORARY TABLE IF NOT EXISTS taskpeople SELECT gst.job_number, '' AS AREA, SUM(gst.amount) AS amount, SUM(gst.weight) AS weight, SUM(gst.area) AS AREA, SUM(qsc.weight) AS taskweight, SUM(qsc.weight)/SUM(gst.weight) AS percent FROM qy_goal_salesman_task gst INNER JOIN qy_goal_area_task gat ON gat.id =gst.area_task_id INNER JOIN qy_goal_company_task gct ON gct.id=gst.company_task_id INNER JOIN qy_goal_sale_cycle_config scc ON scc.id=gct.cycle_id INNER JOIN qy_goal_prod_config gpc ON gpc.id=gst.prod_id AND gpc.cycle_id=scc.id INNER JOIN qy_goal_prod_series_config psc ON psc.id=gpc.prod_series_id AND psc.cycle_id=scc.id INNER JOIN qy_goal_prod_classify_config pcc ON pcc.id = psc.prod_type_id AND pcc.cycle_id=scc.id INNER JOIN qy_goal_client_task_detail ctd ON gst.salesman_id=ctd.id INNER JOIN qingyuan.sys_circle sc ON sc.id=ctd.client_id INNER JOIN crm_c_duty_saler duty ON duty.c_id=sc.id INNER JOIN qyng_sys_user qsu ON qsu.id= duty.User_Id LEFT JOIN qy_sys_countydetail qsc ON qsc.proname=Pro_Name WHERE scc.id=cycleid AND qsc.CreateTime>=(SELECT start_date FROM qy_goal_sale_cycle_config WHERE id=cycleid) AND qsc.CreateTime<=(SELECT end_date FROM qy_goal_sale_cycle_config WHERE id=cycleid) AND qsc.GetTime=(SELECT MAX(GetTime) FROM qy_sys_countydetail) AND gpc.id=prodid AND pcc.id=classid AND psc.id=seriesid AND gst.job_number=job GROUP BY gst.job_number; #将临时表进行数据转换 UPDATE taskpeople SET job_number= ff.User_Name FROM taskpeople e INNER JOIN qyqx.qy_staff ff ON e.job_number=ff.uid; #查出真正的表 SELECT * FROM taskpeople; #删除临时表 DROP TEMPORARY TABLE taskpeople; END$$ DELIMITER ;这段mysql存储过程哪里出现了语法错误
这段 MySQL 存储过程中出现了语法错误,具体来说是在以下这行代码:
```
GROUP BY gst.job_number;
```
末尾多了一个分号,应该改为:
```
GROUP BY gst.job_number;
```
阅读全文