为什么在运行是ai_settings.cm会变为字典

时间: 2024-03-22 11:42:38 浏览: 15
在这段代码中,`ai_settings.cm` 被初始化为一个空字典。在代码的后面,我们向 `ai_settings.cm` 字典中添加了一些键值对,这些键值对被表示为 `(yi*9+yj, [(ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50])` 的形式。 当我们添加键值对时,Python 解释器会根据键的哈希值将其存储在 `ai_settings.cm` 字典中。可以通过以下方式检查 `ai_settings.cm` 的类型: ``` print(type(ai_settings.cm)) ``` 如果输出结果是 `<class 'dict'>`,那么 `ai_settings.cm` 是一个字典类型的变量。在这种情况下, `ai_settings.cm` 是在运行时被赋值为一个字典类型的变量。 由于字典是 Python 中常用的数据结构之一,因此在 Python 中创建和操作字典是非常常见的。
相关问题

为什么在运行是字典ai_settings.cm会变为列表

在这段代码中,`ai_settings.cm` 变成列表的原因可能是因为在代码的后面,我们向 `ai_settings.cm` 中添加了一些键值对,这些键值对可能是以列表的形式添加的,而不是以字典的形式添加的。 例如,如果我们使用以下代码向 `ai_settings.cm` 中添加一个键值对: ``` ai_settings.cm[yi*9+yj] = [(ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50] ``` 则键 `yi*9+yj` 对应的值是一个列表,而不是一个字典。如果这种情况发生了很多次,那么 `ai_settings.cm` 就可能变成一个包含多个列表的列表。 可以通过以下代码检查 `ai_settings.cm` 是否为列表类型: ``` print(type(ai_settings.cm)) ``` 如果输出结果是 `<class 'list'>`,那么 `ai_settings.cm` 是一个列表类型的变量。在这种情况下, `ai_settings.cm` 是在运行时被赋值为一个列表类型的变量。如果我们希望确保 `ai_settings.cm` 始终是一个字典类型的变量,可以在代码中添加以下行: ``` ai_settings.cm = {} ``` 这将在代码的每次运行时将 `ai_settings.cm` 重置为一个空字典。

print(type(ai_settings.cm)) if ai_settings.name_map[yi][yi][0] == '黑': if(ai_settings.cm.get(yi*9+yj)==None): ai_settings.cm[yi*9+yj] = [(ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50] else: ai_settings.cm[yi*9+yj].append((ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50) else: if (ai_settings.cn.get(yi * 9 + yj) == None): ai_settings.cn[yi * 9 + yj] = [(ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50] else: ai_settings.cn[yi*9+yj].append((ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50)

这段代码是 Python 代码。它包含了一些条件语句和字典操作。 首先,代码检查 `ai_settings.name_map` 列表中第 `yi` 行、第 `yj` 列的元素是否为 `'黑'`。如果是,代码将 `(ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50` 添加到字典 `ai_settings.cm` 中以键值对 `(yi*9+yj, [(ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50])` 的形式。如果字典 `ai_settings.cm` 中已经有了键 `yi*9+yj`,则将新的值 `(ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50` 添加到对应的列表中。 如果 `ai_settings.name_map` 列表中第 `yi` 行、第 `yj` 列的元素不是 `'黑'`,则代码将 `(ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50` 添加到字典 `ai_settings.cn` 中以键值对 `(yi*9+yj, [(ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50])` 的形式。如果字典 `ai_settings.cn` 中已经有了键 `yi*9+yj`,则将新的值 `(ai_settings.now_x[i] / 50)*9+ai_settings.now_y[i] / 50` 添加到对应的列表中。 最后,代码返回字典 `ai_settings.cm` 和 `ai_settings.cn`。

相关推荐

import sys import random import pygame from dust import Dust def check_keydown_events(event, robot): if event.key == pygame.K_RIGHT: # move right robot.moving_right = True elif event.key == pygame.K_LEFT: # move left robot.moving_left = True def check_keyup_events(event, robot): if event.key == pygame.K_RIGHT: robot.moving_right = False elif event.key == pygame.K_LEFT: robot.moving_left = False def check_events(robot): # respond to keyboard and mouse item # supervise keyboard and mouse item for event in pygame.event.get(): if event.type == pygame.QUIT: sys.exit() elif event.type == pygame.KEYDOWN: check_keydown_events(event, robot) elif event.type == pygame.KEYUP: check_keyup_events(event, robot) def update_screen(ai_settings, screen, dusts, robot,detector): # fill color 填充颜色 screen.fill(ai_settings.bg_color) # check robot and dust collisions check_robot_dust_collisions(robot, dusts) # draw the dusts dusts.draw(screen) # draw the robot robot.blitme() # draw the detector detector.blitme() # visualiaze the window pygame.display.flip() def create_dust(ai_settings, screen, dusts): """Create dust, and place it in the room.""" dust = Dust(ai_settings, screen) dust.rect.x = random.randint(50, ai_settings.screen_width - 50) dust.rect.y = random.randint(50, ai_settings.screen_height - 50) dusts.add(dust) def create_room(ai_settings, screen, dusts): """Create a full room of dusts.""" for mine_number in range(ai_settings.dust_number): create_dust(ai_settings, screen, dusts) def check_robot_dust_collisions(robot, dusts): """Respond to robot-dust collisions.""" # Remove any robot and dusts that have collided. pygame.sprite.spritecollide(robot, dusts, True, None)

最新推荐

recommend-type

新一代人工智能在智能电网中的应用研究综述_戴彦.pdf

artificial intelligence,AI) 的重要应用领域之一,以高级机器学习理论、大数据、云计算为主要代表的新一代人工智能( new generation artificial intelligence,NGAI) 技术的进步和突破,将会促进智能电网的发展。...
recommend-type

6G移动通信系统_需求_挑战和关键技术_张小飞.pdf

论述了6G系统支撑理论(空间信息论、压缩感知、人工智能)和潜在关键技术(太赫兹通信、可见光通信、非正交多址接入技术、超大规模天线技术、频谱认知技术、个性化的极化码技术、新电池与无线能量传输、定位技术)。...
recommend-type

创意蓝色科技感AI人工智能发布会PPT模板.pptx

人工智能ppt模板 战略发布会模板 大数据介绍或发布模板 市场分析模板 公司科幻背景简介、科技产品介绍、科技型公司宣传手册或宣传模板
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

可见光定位LED及其供电硬件具体型号,广角镜头和探测器,实验设计具体流程步骤,

1. 可见光定位LED型号:一般可使用5mm或3mm的普通白色LED,也可以选择专门用于定位的LED,例如OSRAM公司的SFH 4715AS或Vishay公司的VLMU3500-385-120。 2. 供电硬件型号:可以使用常见的直流电源供电,也可以选择专门的LED驱动器,例如Meanwell公司的ELG-75-C或ELG-150-C系列。 3. 广角镜头和探测器型号:一般可采用广角透镜和CMOS摄像头或光电二极管探测器,例如Omron公司的B5W-LA或Murata公司的IRS-B210ST01。 4. 实验设计流程步骤: 1)确定实验目的和研究对象,例如车辆或机器人的定位和导航。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这