CSP认证2023-03:田地丈量、垦田计划、LDAP,python满分解答代码

news2024/9/20 7:54:43

CSP认证2023-03:田地丈量、垦田计划、LDAP,python满分解答代码

目录

一、田地丈量

问题描述

输入输出 

思路

代码和结果 

二、垦田计划

问题描述

输入和输出 

思路 

代码和结果

三、LDAP 

问题描述

思路

代码和结果 


一、田地丈量

问题描述

输入输出 

输入

4 10 10
0 0 5 5
5 -2 15 3
8 8 15 15
-2 10 3 15

输出 

44

思路

对于每一个选定区域,我们只需要知道此区域的长和宽,即可求出,如上图所示。对于长,需要算出x_1,x_2值(x_1<=x_2,x_2-x_1即为长)。观察上图,x_1实际上是max(x1,0),x_2为min(a,x2)。同理,宽=y_1-y_2,其中y_1<=y_2,y_1=max(0,y1),y_2=min(b,y2)

代码和结果 

n,a,b = list(map(int,input().split()))
result = 0
for i in range(n):
    x1,y1,x2,y2 = list(map(int,input().split()))
    x = min(a,x2)-max(0,x1)
    y = min(b,y2)-max(0,y1)
    if x>0 and y>0:
        result+=x*y
print(result)

二、垦田计划

问题描述

输入和输出 

输入

4 9 2
6 1
5 1
6 2
7 1

输出 

5

思路 

1.将开垦耗时 相同 的 区域,其耗时缩短1天所需资源数量 进行累加存入字典中,因为总的耗时是由耗时最长的区域所决定的(可以看成是木桶效应)

2.从所有区域中耗时最长的时间开始,所需时间不断减少1,直到时间等于每块区域的最少开垦天数或资源不够为止

具体步骤如下:

  • 首先判断需要的资源数是否超过拥有的资源数,若超过则退出循环,否则继续。
  • 记录总耗时减少一天所需要的资源数,它等于 所有耗时超过max_t的区域 耗时减少1天所需的资源数的总和
  • 消耗的资源添加到需要的资源数中

代码和结果

n, m, k = list(map(int, input().split()))
result = 0
t_dict = {}
for i in range(n):
    t_i, c_i = list(map(int, input().split()))
    '''
    将开垦耗时 相同 的 区域,其耗时缩短1天所需资源数量 进行累加,因为总的耗时是由耗时最长的区域所决定的(可以看成是木桶效应)
    例如下述例子:
    3 9 2
    6 1
    5 1
    6 2
    要想让耗时从6变成5,所需资源必须大于等于1+2
    '''
    if t_i not in t_dict.keys():
        t_dict[t_i] = 0
    t_dict[t_i] += c_i
# 对字典进行排序
t_dict = dict(sorted(t_dict.items(), key=lambda d: d[0], reverse=True))#从大到小进行排序,先满足耗时最长的
t_key_list = list(t_dict.keys())
max_t = t_key_list[0]#在不使用任何资源情况下,所需的最长时间
all_resource = 0#所用到的总资源数
des = 0 #耗时减少一天所需要的资源数,它等于 所有 耗时超过max_t的区域 耗时减少1天所需的资源数
while max_t >=k:
    all_resource += des#总资源数进行累加
    if all_resource>m:#需要的资源数超过拥有的资源数
        break
    if t_dict.get(max_t):
        des = des + t_dict[max_t]
    max_t-=1
print(max_t+1)

三、LDAP 

问题描述

思路

 1.通过问题描述可知,我们要处理的数据EXPR形式为

BASE_EXPR 或者 (LOGIC "(" EXPR ")" "(" EXPR ")")

为此可以针对这两种情况分开处理。其中,BASE_EXPR由ATTRIBUTE OPERATOR VALUE组成,这种情况好处理,按照要求进行匹配(查字典)即可;重点是(LOGIC "(" EXPR ")" "(" EXPR ")"),其中涉及了嵌套,即EXPR中包含了EXPR,在处理时首先就要想到使用来处理,具体为通过 左右括号 提取出表达式(数据结构栈的常用作用),不断进行栈进栈出,从而获得结果。

2.在读取用户属性和属性值时,可以考虑将属性和属性值拼起来作为键存入字典中,以便后续的查询计算,代码如下:

attr_and_attr_of_value= str(attr)+":"+str(attr_of_value)
if not user_data.get(attr_and_attr_of_value):
    user_data[attr_and_attr_of_value] = []
user_data[attr_and_attr_of_value].append(DN)

3.定义一个字典用于记录用户是否拥有该属性,代码如下:

has_attr={}#用于记录用户是否拥有该属性
 #记录用户是否拥有key属性
if not has_attr.get(key):
    has_attr[key] =[]
has_attr[key].append(DN)

代码和结果 

n = int(input())
'''
用字典存储用户的数据,具体存储形式如下:
#{'attr:attr_value':[DN_1,DN_2],'attr_1:attr_value_2':[DN_1,DN_2],} 
'''
def my_print(result):
    result = sorted(result)
    for r in result:
        print(r, end=' ')
    print()
def compute_base(judge):#计算原子式
    '''
    :param judge:原子式
    :return:
    '''
    #提取中间的值
    if ":" in judge:
        result = user_data.get(judge)#DN列表,这里也能为空,需要加一个判断
        if not result:
            result = []
    else:
        judge_list = judge.split('~')
        attr = int(judge_list[0])
        attr_of_value = judge_list[1]
        # 做差集即可
        has_attr_user = has_attr[attr]  # 拥有该属性的用户
        # 读取拥有该属性attr,且值为attr_of_value的用户
        has_attr_and_attr_of_value_is = user_data.get(str(attr) + ":" + attr_of_value)
        if not has_attr_and_attr_of_value_is:
            result = has_attr_user
        else:
            result = set(has_attr_user) - set(has_attr_and_attr_of_value_is)
    return result
def get_result(judge):
    #给两边加上括号
    judge = '('+judge+')'#通过 左右括号 提取表达式,数据结构 栈的常用操作
    # 使用栈结构处理数据
    stack = []
    BASE_COMPUTE = []#用于存放原子式的结果
    for i in judge:
        easy_expr =''
        stack.append(i)
        if stack[-1]==')':
            while len(stack)!=0:#栈不为空
                top_stack = stack.pop()
                if top_stack!='(' and top_stack!=')':#不要把括号加进来
                    easy_expr=top_stack+easy_expr
                if top_stack=='(':
                    break
            if easy_expr[0]=='&' or easy_expr[0]=='|':
                base_1 = set(BASE_COMPUTE.pop())#转成集合类型 直接用set的交 并操作
                base_2 = set(BASE_COMPUTE.pop())
                if easy_expr[0]=='&':
                    base = base_1 & base_2
                else:
                    base = base_1 | base_2
                BASE_COMPUTE.append(base)
            else:#当运算为原子式时
                base_result = compute_base(easy_expr)
                BASE_COMPUTE.append(base_result)
    return BASE_COMPUTE.pop()

user_data ={}
has_attr={}#用于记录用户是否拥有该属性
for i in range(n):
    data = list(map(int,input().split()))
    DN = data[0]#用户DN
    number_of_attr = data[1]#用户包含的属性值
    for j in range(1,number_of_attr+1):
        key = data[2*j]

        #记录用户是否拥有key属性
        if not has_attr.get(key):
            has_attr[key] =[]
        has_attr[key].append(DN)
        value = data[2*j+1]
        attr_and_attr_of_value= str(key)+":"+str(value)
        if not user_data.get(attr_and_attr_of_value):
            user_data[attr_and_attr_of_value] = []
        user_data[attr_and_attr_of_value].append(DN)
m = int(input())
for i in range(m):
    judge  = input()
    if len(judge)==3:#原子表达式,长度为3
        result = compute_base(judge)
        my_print(result)
    else:#否则为复合式
        result = get_result(judge)
        my_print(result)

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

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

相关文章

在ubuntu虚拟机上安装不同版本的交叉编译工具链

在之前的章节中&#xff0c;学习了如何安装了4.8.3的交叉编译工具链&#xff1a; 交叉编译 和 软硬链接 的初识&#xff08;面试重点&#xff09;-CSDN博客 但是&#xff0c;在之后学习内核编译时&#xff0c;由于我的树莓派内核版本较高&#xff0c;为6.1&#xff0c;所以在…

贪心 55. 跳跃游戏 45.跳跃游戏 II

55. 跳跃游戏 题目&#xff1a; 给定非负数组&#xff0c;初始位置在数组第一格&#xff0c;数组值是可以选择的最大跳跃步数&#xff0c;判断能不能达到数组末尾。 示例 1: * 输入: [2,3,1,1,4] * 输出: true * 解释: 我们可以先跳 1 步&#xff0c;从位置 0 到达 位置 1,…

【多传感器融合】BEVFusion: 激光雷达和视觉融合框架 NeurIPS 2022

前言 BEVFusion其实有两篇&#xff0c; 【1】BEVFusion: A Simple and Robust LiDAR-Camera Fusion Framework. NeurIPS 2022 | 北大&阿里提出 【2】BEVFusion: Multi-Task Multi-Sensor Fusion with Unified Bird’s-Eye View Representation 2022 | MIT提出 本文先分…

VUE2+THREE.JS点击事件

THREE.JS点击事件 1.增加监听点击事件2.点击事件实现3.记得关闭页面时 销毁此监听事件 1.增加监听点击事件 renderer.domElement.addEventListener("click", this.onClick, false); 注:初始化render时监听 2.点击事件实现 onClick(event) {const raycaster new …

leetcode-142-环形链表(C语言实现)

题目&#xff1a; 给定一个链表的头节点 head &#xff0c;返回链表开始入环的第一个节点。 如果链表无环&#xff0c;则返回 null。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评…

药食同源的食物哪些适合冬季吃?

药食同源的食物是指在中医理论指导下&#xff0c;既是药物又是食物的天然植物和动物&#xff0c;具有营养和药效双重作用。在冬季&#xff0c;由于气候寒冷&#xff0c;人体需要更多的热量和营养来保持温暖和健康&#xff0c;因此药食同源的食物在冬季特别适合食用。以下是几种…

CSS伪类伪元素?:hover,::before,::after使用(举例)

文章目录 什么是CSS伪类&#xff1f;什么是伪元素&#xff1f;怎么用伪元素&#xff1f;可以做些什么&#xff1f;::before&#xff0c;在标签选择器之前添加内容&#xff0c;::after正好与之相反::before&#xff0c;在类选择器之前添加内容&#xff08;:制作一个悬浮提示窗 参…

认识JVM 一个Java文件的JVM之旅

准备 我是一个java文件&#xff0c;如何实现我的功能呢&#xff1f;需要去JVM(Java Virtual Machine)这个地方旅行。 变身 我高高兴兴的来到JVM&#xff0c;想要开始JVM之旅&#xff0c;它确说&#xff1a;“现在的我还不能进去&#xff0c;需要做一次转换&#xff0c;生成c…

Ubuntu镜像与K8S冲突,容器持续Terminating

问题 记录一次软件冲突BUG&#xff1a; eclipse-temurin:11-jdk&#xff08;底层Ubuntu 20.04.3 LTS&#xff09;镜像创建的容器在K8S-1.25.5上无法正常terminating&#xff0c;造成资源浪费&#xff0c;甚至引发K8S资源CPU insufficient报错。具体表现 某些容器镜像在K8S上无…

20个Python源码项目下载

20个很不错的Python项目源码&#xff0c;其中包括适合毕业设计的项目。这些资源中涵盖了Django 3版本的项目&#xff1a; DjangoMysqlBulma实现的商场管理系统源码 PythonDjango实现基于人脸识别的门禁管理系统 PythonFlaskMySQL实现的学生培养计划管理系统 Python大熊猫主题人…

Windows本地搭建Emby媒体库服务器并实现远程访问「内网穿透」

文章目录 1.前言2. Emby网站搭建2.1. Emby下载和安装2.2 Emby网页测试 3. 本地网页发布3.1 注册并安装cpolar内网穿透3.2 Cpolar云端设置3.3 Cpolar内网穿透本地设置 4.公网访问测试5.结语 1.前言 在现代五花八门的网络应用场景中&#xff0c;观看视频绝对是主力应用场景之一&…

Linux基本指令(中篇)

目录 8.cp指令&#xff08;重要&#xff09; 9.mv指令&#xff08;重要&#xff09;&#xff1a; 10.cat指令&#xff08;适合查看小文件内容&#xff09; 11.more指令&#xff08;适合查看大文件内容&#xff09; 12.less指令&#xff08;重要&#xff09; 13.head指令和…

SpringBoot 整合 Neo4j 实战(头歌)

文章目录 第1关&#xff1a;认识 Spring DATA Neo4J任务描述相关知识Spring DATA Neo4J - 简介Spring JDBC / Spring ORM 模块的缺点&#xff1a;Spring 数据模块的优点&#xff1a;Spring 数据模块功能&#xff1a;Spring DATA Neo4j 模块的附加功能&#xff1a; Spring DATA …

【腾讯云云上实验室】个人对腾讯云向量数据库的体验心得

目录 前言Tencent Cloud VectorDB概念使用初体验腾讯云向量数据库的优势应用场景有哪些&#xff1f;未来展望番外篇&#xff1a;腾讯云向量数据库的设计核心结语 前言 还是那句话&#xff0c;不用多说想必大家都能猜到&#xff0c;现在技术圈最火的是什么&#xff1f;非人工智…

HyperBDR云容灾v4.10.1发布,划重点:支持UCloud云平台自动化容灾+新增可灵活定义的备份策略

版本更新 HyperBDR云容灾v4.10.1版本来啦&#xff01; 此次更新为大家带来了多个新功能&#xff0c;下面让我们来看看具体是哪些吧~ 01 策略管理新功能&#xff1a; 多时间段限速功能&#xff1a; 更加灵活的多个时间段限速选择&#xff0c;可以在创建策略时为不同的时间段设…

JavaEE——简单认识CSS

文章目录 一、简单了解什么是 CSS二、CSS 选择器1.标签选择器2.类选择器3.ID 选择器4.后代选择器5.子选择器6.伪类选择器 三、字体属性1.设置字体家族2.设置字体大小3.设置字体粗细4.文字倾斜 四、文本属性1.文本对齐2.文本装饰3.文本缩进4.背景设置 五、圆角矩形六、CSS 盒子模…

【猜数字游戏】用wxPython实现:基本的游戏框架 + 简单的图形用户界面

【猜数字游戏】 写在最前面猜数字游戏 实现【猜数字游戏】安装wxPython全部代码代码解析1. 初始化界面2. 生成随机数3. 处理猜测4. 特殊功能5. 分数计算 游戏小程序呈现结语 写在最前面 看到了一个比较有意思的问题 https://ask.csdn.net/questions/8038039 猜数字游戏 在这…

人工智能_机器学习056_拉格朗日乘子法原理推导_公式由来详解_原理详解---人工智能工作笔记0096

https://blog.csdn.net/Soft_Po/article/details/118332454 这里有老师的一篇文章介绍拉格朗日乘子法的原理推导 结合老师的这篇文章我们来看一下详细的推导过程 可以看到上一节我们说,一个有条件的,函数,可以转换为一个,无条件的函数, 根据拉格朗日乘子法,可以创建出一个等…

3.C转python

1.int()默认是按照十进制来转换的 2.在python中没有字符 3.可以这样写 4.特例 这样写才对(要空语句即pass空语句来占位) 5.python中没有swicth语句 6.while循环例子 7.死循环有时不是Bug 8.for循环例子 其中的range()函数中的第三个常数是步长 例子 再一个例子 9.使用shif…

【Node.js】笔记整理4 - 版本管理工具nvm

写在最前&#xff1a;跟着视频学习只是为了在新手期快速入门。想要学习全面、进阶的知识&#xff0c;需要格外注重实战和官方技术文档&#xff0c;文档建议作为手册使用 系列文章 【Node.js】笔记整理 1 - 基础知识【Node.js】笔记整理 2 - 常用模块【Node.js】笔记整理 3 - n…