Python-VBA函数之旅-oct函数

news/2024/5/19 1:51:25

目录

一、oct函数的常见应用场景

二、oct函数使用注意事项

三、如何用好oct函数?

1、oct函数:

1-1、Python:

1-2、VBA:

2、推荐阅读:

个人主页:神奇夜光杯-CSDN博客 

 

一、oct函数的常见应用场景

        oct函数在 Python 中主要用于将整数转换为八进制表示形式,这在某些特定的应用场景下是非常有用的,常见的应用场景有:

1、文件权限检查:在Unix和Linux系统中,文件权限通常使用八进制表示。例如,权限 `755` 表示所有者有读、写和执行权限,组用户和其他用户只有读和执行权限,使用oct()函数可以帮助你更容易地理解或操作这些权限。

2、位操作与位掩码:在处理位级操作时(如设置、清除或检查特定的位),八进制表示法可以提供一个简洁的方式来查看和操作位模式,虽然十六进制(使用hex()函数)在这种情况下更常见,但八进制在某些情况下可能更直观。

3、硬件编程和通信:在硬件编程和与硬件设备的通信中,八进制数经常用于表示二进制数据的分组,例如,在串行通信中,数据可能以字节为单位发送,每个字节由8位二进制数组成,可以很容易地转换为两个八进制数字。

4、调试和日志记录:在开发和调试过程中,有时需要查看和操作整数的二进制或八进制表示形式,使用oct()函数可以方便地获取这些表示形式,并将其记录到日志或输出到控制台中。

5、配置与设置:在某些应用程序或系统中,配置设置可能需要以八进制形式表示,使用oct()函数可以将用户输入的整数转换为相应的八进制表示形式,然后将其存储在配置文件中或用于配置系统参数。

6、数据验证和检查:在某些情况下,你可能需要验证一个数字是否是一个有效的八进制数,虽然oct()函数本身不会进行验证(它会尝试将任何整数转换为八进制字符串),但你可以使用它来帮助你构建这样的验证逻辑。

7、算法和数据处理:在处理二进制数据或进行需要位操作的算法时,八进制表示法可能更易于人类理解和操作,虽然Python主要使用十六进制(hex()函数)来表示较大的二进制数,但在某些情况下,八进制可能更直观。

8、密码学与安全:虽然八进制本身在密码学和安全领域中的应用可能不如十六进制或二进制普遍,但在某些特定的上下文中,oct()函数仍然可能有用,特别是当处理与权限、访问控制或其他基于位的策略相关的安全功能时。

9、性能优化和内存管理:虽然oct()函数本身可能不是性能优化的关键部分,但在处理大量位数据或执行复杂的位操作时,将整数转换为八进制字符串以进行日志记录、调试或可视化可能会帮助你更有效地管理和优化你的代码和内存使用。

        注意,虽然oct()函数在某些特定场景下可能非常有用,但在大多数日常编程任务中,你可能更常使用十进制、二进制或十六进制数,然而,了解这些不同的数字系统和如何在Python中进行转换仍然是非常重要的。

二、oct函数使用注意事项

        在Python中使用oct()函数时,需要注意以下几点:

1、输入类型:oct()函数只接受整数类型的参数,如果你尝试将一个非整数(如浮点数、字符串等)传递给oct()函数,Python会引发一个TypeError异常。

2、输出格式:在Python 3中,oct()函数返回的字符串表示形式带有0o前缀,表示这是一个八进制数,如果你需要不带前缀的字符串,可以使用字符串切片来去除它;在Python 2中,oct()函数返回的字符串表示形式没有0o前缀。

3、大整数的表示:对于非常大的整数,oct()函数能够正确地将它们转换为八进制表示形式,而不用担心整数溢出或精度问题。

4、性能:虽然oct()函数在大多数情况下都非常快,但如果你在处理大量数据时需要频繁调用它,可能会对性能产生影响,在这种情况下,可以考虑使用其他方法来优化你的代码。

5、进制间的转换:如果你需要在八进制、二进制和十六进制之间进行转换,需要小心使用oct()、bin()和hex()函数,并理解它们返回的字符串表示形式,特别是要注意前缀(`'0o'`、`'0b'`和`'0x'`)的存在与否。

6、整数范围:oct()函数能够处理Python中的任意整数(在理论上是无限的,但在实践中受到可用内存的限制),但是,如果你试图将超出Python整数范围的值传递给oct()函数(这在实际中是不可能发生的,因为Python整数可以扩展到任何大小),Python将引发一个OverflowError(尽管这在实际中几乎不可能发生)。

7、国际化和编码:虽然oct()函数返回的字符串是ASCII编码的,但在处理国际化或特殊编码的文本时,需要确保你的代码能够正确处理这些字符串,这通常不是oct()函数本身的问题,而是整个应用程序或系统需要关注的问题。

三、如何用好oct函数?

        在Python中,oct()函数主要用于将整数转换为八进制字符串表示,要用好oct()函数,你最好遵循以下建议:

1、明确输入类型:确保你传递给oct()函数的参数是整数类型;如果参数是其他类型(如浮点数、字符串等),你需要先将其转换为整数。

2、处理输出格式:Python 3中的oct()函数返回的字符串以0o开头,表示这是一个八进制数,如果你不需要这个前缀,可以使用字符串切片来去除它。

3、理解八进制表示:八进制是一种基数为8的数制系统,使用数字0-7来表示,了解八进制的基本概念可以帮助你更好地理解和使用oct()函数。

4、错误处理:当处理用户输入或不确定的数据时,应该添加适当的错误处理来捕获可能的异常。例如,你可以使用`try-except`块来捕获并处理TypeError(如果传递给oct()函数的参数不是整数)。

5、避免不必要的转换:如果你已经有一个八进制字符串(例如从文件或用户输入中读取的),并且你只是想对其进行操作或显示,那么就没有必要使用oct()函数将其转换回整数再转换回字符串,直接操作字符串可能会更高效。

6、结合其他函数使用:你可以将oct()函数与其他Python函数结合使用,以执行更复杂的任务。例如,你可以使用字符串方法(如split()、replace()等)来进一步处理oct()函数返回的字符串。

7、文档和注释:在你的代码中使用oct()函数时,添加适当的文档和注释可以帮助其他人(或未来的你)更好地理解你的代码是如何工作的,解释为什么你选择使用八进制表示,以及你如何使用oct()函数来实现你的目标。

8、测试:编写测试用例来验证你的代码是否正确地使用了oct()函数,确保你的代码能够处理各种边界情况和异常情况。

1、oct函数:
1-1、Python:
# 1.函数:oct
# 2.功能:用于将整数转换为带前缀"0o"的八进制数字符串
# 3.语法:oct(x)
# 4.参数:x,必须参数,表示一个整数值
# 5.返回值:返回一个字符串,该字符串表示参数x的八进制形式
# 6.说明:
# 7.示例:
# 用dir()函数获取该函数内置的属性和方法
print(dir(oct))
# ['__call__', '__class__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__',
# '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__name__',
# '__ne__', '__new__', '__qualname__', '__reduce__', '__reduce_ex__', '__repr__', '__self__', '__setattr__', '__sizeof__',
# '__str__', '__subclasshook__', '__text_signature__']# 用help()函数获取该函数的文档信息
help(oct)# 应用一:文件权限检查
import os
import stat
def get_file_permissions(file_path):# 使用os.stat获取文件状态信息stat_info = os.stat(file_path)# 使用stat.S_IMODE从文件状态信息中提取权限位permissions = stat.S_IMODE(stat_info.st_mode)# 使用oct()将权限位转换为八进制字符串表示,并去除'0o'前缀octal_permissions = oct(permissions)[2:]return octal_permissions
def check_file_permissions(file_path, required_permissions):# 获取文件的八进制权限file_perms = get_file_permissions(file_path)# 将所需权限也转换为八进制字符串(如果它们不是已经是的话)if not required_permissions.startswith('0') and not required_permissions.startswith('o'):required_perms_int = int(required_permissions, 8)  # 假设required_permissions是有效的八进制字符串required_perms = oct(required_perms_int)[2:]# 检查文件权限是否包含所需权限# 这里我们简单地检查required_permissions是否是file_perms的子集(即每个位都是1的地方,file_perms也必须是1)# 这可以通过将两者转换为整数并执行位与操作来完成,然后检查结果是否等于required_permissions对应的整数required_perms_int = int(required_permissions, 8)file_perms_int = int(file_perms, 8)has_required_perms = (file_perms_int & required_perms_int) == required_perms_intreturn has_required_perms
# 使用示例
file_path = 'file.txt'  # 替换为你的文件路径
print(f"File permissions for '{file_path}': {get_file_permissions(file_path)}")
# 检查文件是否具有特定的权限,比如 644(读/写 对拥有者, 只读 对组和其他用户)
required_permissions = '644'
if check_file_permissions(file_path, required_permissions):print(f"The file '{file_path}' has the required permissions '{required_permissions}'.")
else:print(f"The file '{file_path}' does not have the required permissions '{required_permissions}'.")
# File permissions for 'file.txt': 666
# The file 'file.txt' has the required permissions '644'.# 应用二:位操作与位掩码
def bitwise_operations_and_mask(num1, num2, mask):# 位与操作and_result = num1 & num2print(f"num1: {oct(num1)[2:]} & num2: {oct(num2)[2:]} = {oct(and_result)[2:]}")# 位或操作or_result = num1 | num2print(f"num1: {oct(num1)[2:]} | num2: {oct(num2)[2:]} = {oct(or_result)[2:]}")# 位异或操作xor_result = num1 ^ num2print(f"num1: {oct(num1)[2:]} ^ num2: {oct(num2)[2:]} = {oct(xor_result)[2:]}")# 位非操作(注意这里是对单个数进行的)not_result = ~num1print(f"~num1: {oct(num1)[2:]} = {oct(not_result)[2:]} (注意:位非操作的结果依赖于整数的位数)")# 位掩码操作masked_result = num1 & maskprint(f"num1: {oct(num1)[2:]} & mask: {oct(mask)[2:]} = {oct(masked_result)[2:]}")
# 示例数值(以十进制表示,但实际上是进行二进制位操作)
num1 = 0b1100  # 二进制 1100,十进制 12
num2 = 0b1010  # 二进制 1010,十进制 10
mask = 0b1100  # 掩码,二进制 1100,十进制 12
# 执行位操作和位掩码
bitwise_operations_and_mask(num1, num2, mask)
# num1: 14 & num2: 12 = 10
# num1: 14 | num2: 12 = 16
# num1: 14 ^ num2: 12 = 6
# ~num1: 14 = o15 (注意:位非操作的结果依赖于整数的位数)
# num1: 14 & mask: 14 = 14# 应用三:硬件编程和通信
# 假设我们有一个硬件寄存器,它存储了一个8位的值
# 我们使用整数来表示这个值,因为Python中的整数是以二进制形式存储的
def read_register(address):# 在真实情况下,这里会是一个与硬件通信的函数# 假设我们有一个模拟的寄存器映射registers = {0x01: 0b11001010,  # 假设这是地址0x01的寄存器值# ... 其他寄存器值}return registers.get(address, 0)  # 如果地址不存在,返回0
def write_register(address, value):# 在真实情况下,这里会是一个与硬件通信的函数# 在这个模拟示例中,我们只是打印出写入的地址和值print(f"Writing to register 0x{address:02X}: 0b{value:08b} (octal: 0o{oct(value)[2:]})")
# 读取寄存器并显示其八进制表示
register_address = 0x01
register_value = read_register(register_address)
print(f"Register 0x{register_address:02X} value: 0b{register_value:08b} (octal: 0o{oct(register_value)[2:]})")
# 写入一个值到寄存器(模拟)
new_value = 0b10101010
write_register(register_address, new_value)
# Register 0x01 value: 0b11001010 (octal: 0o312)
# Writing to register 0x01: 0b10101010 (octal: 0o252)# 应用四:调试和日志记录
import logging
# 配置一个简单的日志记录器
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
def process_data(data):# 假设我们有一些二进制数据处理函数# 在这里,我们只是简单地将数据左移一位processed_data = data << 1# 使用oct()将处理后的数据转换为八进制,并记录到日志中logging.info(f"Original data (decimal): {data}, (binary): {bin(data)[2:]}, (octal): {oct(data)[2:]}")logging.info(f"Processed data (decimal): {processed_data}, (binary): {bin(processed_data)[2:]}, (octal): {oct(processed_data)[2:]}")# 返回处理后的数据(在实际应用中可能不需要返回)return processed_data
# 示例使用
data = 0b1100  # 二进制数据
processed_data = process_data(data)
# 这里只是为了演示,实际中processed_data可能用于后续操作
print(f"Processed data (decimal): {processed_data}")
# Processed data (decimal): 24
# 2024-05-04 22:38:25,704 - INFO - Original data (decimal): 12, (binary): 1100, (octal): 14
# 2024-05-04 22:38:25,704 - INFO - Processed data (decimal): 24, (binary): 11000, (octal): 30# 应用五:配置与设置
import logging
# 假设我们有一个配置字典,其中包含一些八进制表示的设置
config = {'file_permissions': 0o644,  # 八进制表示的文件权限'device_setting': 0o377,  # 假设的硬件设置,以八进制表示# ... 其他设置
}
# 配置日志记录器
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
def configure_and_log_settings(config_dict):# 遍历配置字典for setting_name, setting_value in config_dict.items():# 检查设置值是否为整数(这里简化为只处理整数)if isinstance(setting_value, int):# 使用oct()将整数转换为八进制字符串,并去除'0o'前缀octal_str = oct(setting_value)[2:]# 记录日志logging.info(f'Setting {setting_name} configured to octal {octal_str} (decimal {setting_value})')else:# 对于非整数设置,简单记录其值logging.info(f'Setting {setting_name} configured to {setting_value}')
# 调用函数配置并记录日志
configure_and_log_settings(config)
# 2024-05-04 22:40:46,874 - INFO - Setting file_permissions configured to octal 644 (decimal 420)
# 2024-05-04 22:40:46,874 - INFO - Setting device_setting configured to octal 377 (decimal 255)# 应用六:算法和数据处理
def add_octal_numbers(octal1, octal2):# 将八进制字符串转换为整数num1 = int(octal1, 8)num2 = int(octal2, 8)# 计算两个整数的和sum_decimal = num1 + num2# 将和转换回八进制字符串sum_octal = oct(sum_decimal)[2:]  # 去掉'0o'前缀return sum_octal
# 示例用法
octal1 = "123"  # 八进制数 123
octal2 = "456"  # 八进制数 456
# 计算和并打印结果
result = add_octal_numbers(octal1, octal2)
print(f"The sum of {octal1} and {octal2} in octal is: {result}")
# 注意:由于八进制数的范围有限(0-7),如果和超过了单个八进制数字可以表示的范围,
# 则结果将包含多个八进制数字。例如,八进制中的 7 + 1 等于 10(在十进制中是 8),
# 但在八进制中表示为 '10' 而不是 '8'。
# The sum of 123 and 456 in octal is: 601# 应用七:密码学与安全
def octal_encode(data, key):"""简化的“编码”函数,将字符串的每个字符的ASCII码与八进制密钥进行简单的异或操作这不是一个安全的加密方法,仅用于展示八进制在数据处理中的应用:param data: 要编码的字符串:param key: 八进制表示的密钥(将被转换为整数):return: 编码后的字符串(其ASCII码与密钥进行了异或操作)"""# 将八进制密钥转换为整数key_int = int(key, 8)# 对字符串的每个字符进行异或操作encoded_data = ''.join(chr(ord(c) ^ key_int) for c in data)return encoded_data
def octal_decode(encoded_data, key):"""解码函数,与编码函数相反:param encoded_data: 编码后的字符串:param key: 八进制表示的密钥(将被转换为整数):return: 解码后的原始字符串"""# 将八进制密钥转换为整数key_int = int(key, 8)# 对编码后的字符串的每个字符进行异或操作以恢复原始数据decoded_data = ''.join(chr(ord(c) ^ key_int) for c in encoded_data)return decoded_data
# 示例用法
original_data = "Hello, Python!"
key = "1024"  # 八进制密钥,对应十进制的 83
# 编码数据
encoded_data = octal_encode(original_data, key)
print(f"Encoded data: {encoded_data}")
# 解码数据
decoded_data = octal_decode(encoded_data, key)
print(f"Decoded data: {decoded_data}")
# 应该输出原始数据
assert decoded_data == original_data
# Encoded data: ɜɱɸɸɻȸȴɄɭɠɼɻɺȵ
# Decoded data: Hello, Python!# 应用八:性能优化和内存管理
# 假设我们有一个整数列表,我们需要将它们转换为八进制字符串列表
numbers = [10, 20, 30, 40, 50]
# 使用传统的循环和append方法
octal_strings_traditional = []
for num in numbers:octal_strings_traditional.append(oct(num)[2:])  # 去掉 '0o' 前缀
# 使用列表推导式
octal_strings_list_comp = [oct(num)[2:] for num in numbers]
# 列表推导式通常更快,因为它利用了Python的内部优化
# 在这个例子中,它还减否产生相同的结果  少了代码量并提高了可读性
# # 输出结果以验证两种方法是
print(octal_strings_traditional)
print(octal_strings_list_comp)
# ['12', '24', '36', '50', '62']
# ['12', '24', '36', '50', '62']
1-2、VBA:
略,待后补。
2、推荐阅读:

2-1、Python-VBA函数之旅-globals()函数

Python算法之旅:Algorithm

Python函数之旅:Functions

个人主页:神奇夜光杯-CSDN博客 

http://www.mrgr.cn/p/66266615

相关文章

推荐一个好用的命令行工具ShellGPT

ShellGPT 配置安装常用功能聊天写命令并执行 高级功能函数调用角色管理 总结 这两天突然想到&#xff0c;现有的很多工具都在被大模型重构&#xff0c;比如诞生了像perplexity.ai 这种新交互形式的搜索引擎&#xff0c;就连wps也推出了AI服务&#xff0c;甚至都可以直接生成ppt…

k8s核心组件详解和分层架构

k8s核心组件master中的核心组件api-server(接口服务,基于rest风格开放k8s接口的服务) kube-controller-manager(管理各个类型的控制器,针对k8s中的各种资源进行管理)cloud-controller-manager(云控制管理器,第三方云平台提供的控制器,api对接管理功能) kube-scheduler…

QT中的容器

Qt中的容器 关于Qt中的容器类&#xff0c;下面我们来进行一个总结&#xff1a; Qt的容器类比标准模板库&#xff08;STL&#xff09;中的容器类更轻巧、安全和易于使用。这些容器类是隐式共享和可重入的&#xff0c;而且他们进行了速度和存储的优化&#xff0c;因此可以减少可…

前端框架开发之Niu框架——从零学框架的小白

起因: 从2018年6月一直到我重新提笔,6年时间。这六年时间,我见证了IT的兴衰,见证了小众框架LayUI框架的重新更新,见证了vue、angular、react等框架的主流。----博客园老牛大讲堂初衷: 今年我突发灵感,想要设计一个网站,作为程序员却"提笔忘字",就连最基本的…

【webrtc】MessageHandler 7: 基于线程的消息处理:切换main线程向observer发出通知

以当前线程作为main线程 RemoteAudioSource 作为一个handler 仅实现一个退出清理的功能 首先on message的处理会切换到main 线程 :main_thread_其次,这里在main 线程对sink_ 做清理再次,在main 线程做出状态改变,并能通知给所有的observer 做出on changed 行为。对接mediac…

Blazor流程编排的艺术:深入Z.Blazor.Diagrams库的使用与实践

为现代网页应用开发提供动力的其中一个重要方面就是前端框架的强大功能与灵活性。而在.NET生态中,Blazor以其独特的工作方式和优势逐渐获得了开发者们的青睐。今天,在这篇文章中,我将带你深入探索一个基于Blazor的优秀库——Z.Blazor.Diagrams,我们将了解它是如何帮助开发者…

设计模式: 工厂模式

工厂模式&#xff08;Factory Pattern&#xff09;是 Java 中最常用的设计模式之一&#xff0c;这种类型的设计模式属于创建型模式&#xff0c;它提供了一种创建对象的最佳方式。 工厂模式提供了一种创建对象的方式&#xff0c;而无需指定要创建的具体类。 工厂模式属于创建型…

【未整合】数学 day4.2

博弈论 Nim游戏 对于 \(n=2\),\(a_1=a_2\),后手可以“模仿”先手,使得后手必胜。 对于 \(a_1\ne a_2\),先手可以让自己进入“模仿期”,使得先手必胜。 结论:若 \(\oplus a_i=0\),先手必败,否则必胜。很神奇的东西,证明需要群论知识。 发现石子的合并满足上面四条性质,…

Jmeter内存溢出:java.lang.OutOfMemoryError: Java heap space解决思路

一、问题原因 用JMeter压测,有时候当模拟并发请求较大或者脚本运行时间较长时,JMeter会停止,报OOM(内存溢出)错误。原因是JMeter是一个纯Java开发的工具,内存由java虚拟机JVM管理,当内存回收不及时,堆内存不足时,就会报内存溢错误。 概念补充: 内存泄露:应用使用资源…

java基于云计算的SaaS医院his信息系统源码 HIS云平台源码

目录 云HIS功能模块 1、预约挂号&#xff1a; 2、药库管理&#xff1a; 3、门诊医生站&#xff1a; 4、门诊费用&#xff1a; 5、药房管理&#xff1a; 6、治疗室&#xff08;门诊护士工作站&#xff09;&#xff1a; 7、统计分析&#xff1a; 8、财务管理&#xff1a;…

C++多态特性详解

目录 概念&#xff1a; 定义及实现&#xff1a; 虚函数重写的两个例外&#xff1a; 1.协变&#xff1a; 2.析构函数的重写&#xff1a; final关键字&#xff1a; override关键字&#xff1a; 多态是如何实现的&#xff08;底层&#xff09;&#xff1a; 面试题&#xff1…

RabbitMQ(Docker 单机部署)

序言 本文给大家介绍如何使用 Docker 单机部署 RabbitMQ 并与 SpringBoot 整合使用。 一、部署流程 拉取镜像 docker pull rabbitmq:3-management镜像拉取成功之后使用下面命令启动 rabbitmq 容器 docker run \# 指定用户名-e RABBITMQ_DEFAULT_USERusername \# 指定密码-e R…

www.fastssh.com SSH over WebSockets with CDNs

https://www.fastssh.com/page/create-ssh-cdn-websocket/server/这其实不是标准的websocket报文(服务器响应报文无Sec-Websocket-Accept字段)&#xff0c;所以无法使用github.com/gorilla/websocket包&#xff1a;GET / HTTP/1.1 Host: hostname:8080 User-Agent: Go-http-cli…

深度学习相关理论

一、深度学习相关理论 1.神经网络概述 2. 卷积神经网络CNN ①卷积层——计算方法是大矩阵内部小矩阵=较小矩阵,作用是特征提取 ②池化层——计算方法是大矩阵通过选取最大值或是平均值变成小矩阵,作用是降维、提高计算效率 3. 激活函数

自动化机器学习——网格搜索法:寻找最佳超参数组合

自动化机器学习——网格搜索法&#xff1a;寻找最佳超参数组合 在机器学习中&#xff0c;选择合适的超参数是模型调优的关键步骤之一。然而&#xff0c;由于超参数的组合空间通常非常庞大&#xff0c;手动调整超参数往往是一项耗时且困难的任务。为了解决这个问题&#xff0c;…

OSPF优化

OSPF的优化主要目的是为了减少LSA的更新量 路由汇总-----可以减少骨干区域的LSA数量 特殊区域-----可以减少非骨干区域的LSA数量 OSPF路由汇总 域间路由汇总 域间路由汇总在ABR设备上进行操作 [GS-R2-ospf-1-area-0.0.0.1]abr-summary 192.168.0.0 255.255.224.0 [GS-R3-o…

关于diffusion model一些统计和数学的基础知识

likelihood-based models,通过(近似)最大似然直接学习分布的probability density(或mass)函数。典型的基于似然的模型包括自回归模型、归一化流模型、基于能量的模型(EBMs)和变分自编码器(VAEs)。 概率质量函数(Probability Mass Function,PMF):概率质量函数用于描述离散随…

UE4 -- 实现用于网络连接的插件

插件 UE中的插件就相当于一个模块,在引擎界面点击创建新的插件后,会在项目文件夹中生成插件的文件夹,在该文件夹内,只需要像游戏项目一样编写插件逻辑,最后在插件选择界面开启该插件即可 当新建插件后,UE会自动生成继承于IModuleInterface的类,说明该文件夹的内容为插件…

OKR-Periods of Words

[POI2006] OKR-Periods of Words 题面翻译 对于一个仅含小写字母的字符串 \(a\),\(p\) 为 \(a\) 的前缀且 \(p\ne a\),那么我们称 \(p\) 为 \(a\) 的 proper 前缀。 规定字符串 \(Q\) 表示 \(a\) 的周期,当且仅当 \(Q\) 是 \(a\) 的 proper 前缀且 \(a\) 是 \(Q+Q\) 的前缀。…

Unity技术学习:RenderMesh、RenderMeshInstanced

叠甲&#xff1a;本人比较菜&#xff0c;如果哪里不对或者有认知不到的地方&#xff0c;欢迎锐评&#xff08;不玻璃心&#xff09;&#xff01; 导师留了个任务&#xff0c;渲染大量的、移动的物体。 当时找了几个解决方案&#xff1a; 静态批处理&#xff1a; 这东西只对静…