Python-VBA编程500例-022(入门级)

news2024/11/24 19:12:07

最长AB子串(Longest AB Alternating Substring)(或称为最长XY出现次数相同的子字符串)这个问题看似是一个比较抽象的编程问题,但在实际应用场景中,它可以用来解决一系列涉及平衡性和重复模式的实际问题。常见应用场景有:

1、DNA或RNA序列分析:在生物信息学中,最长AB子串问题可以用于分析DNA或RNA序列中特定碱基对的平衡性。例如,在寻找可能的蛋白质编码区域时,需要分析序列中碱基对的出现次数和平衡性。

2、信号处理:在信号处理领域,特别是当涉及到具有周期性或重复性模式的信号时,最长AB子串算法可以用于识别和分析这些模式。

3、网络通信协议:在网络通信中,特定的数据帧或数据包可能需要满足一定的格式要求,包括某些字段的出现次数和顺序。最长AB子串算法可以用于验证这些要求是否得到满足。

4、编码与解码:在一些编码和解码算法中,可能需要确保编码后的字符串中特定字符或字符组合的出现次数保持平衡。最长AB子串算法可以用于验证和优化这些编码策略。

5、文本分析:在自然语言处理或文本挖掘中,最长AB子串问题可能用于分析文本中特定单词或短语的出现频率和分布,从而揭示文本的结构或主题。

6、数据压缩:在数据压缩算法中,寻找最长AB子串可以帮助识别重复的模式,从而更有效地压缩数据。

7、编程竞赛与算法训练:这个问题也是算法竞赛和编程训练中常见的题目,用于检验选手的算法设计和优化能力。

总的来说,最长AB子串问题虽然看似简单,但在实际应用中具有广泛的用途。它涉及到模式识别、平衡性分析、优化等多个方面,对于解决一系列实际问题具有重要意义。

 

1、最长AB子串:
1-1、Python:
# 1.问题描述:
# 给出一个只由字母X和Y组成的字符串str1,找一个最长的子串,要求这个子串里面X和Y的数目相等,并输出该子串的长度.
# 2.问题示例:
# 输入str1= "XYXXXYYYX",输出8.
# 3.代码实现:
class Solution:
    # 参数str1: 待查字符串
    # 返回值answer: 整数,即最大字符串的长度
    def get_substring_longest(self, str1):
        # 初始化一个变量answer,用于记录最长子串的长度,初始值为0
        answer = 0
        # 初始化一个列表arr1,长度为str1的长度,所有元素初始值为0
        arr1 = [0] * len(str1)
        # 初始化一个空字典sets,用于存储差值与对应位置的关系
        sets = {}
        # 判断str1的第一个字符是否为'X'
        if str1[0] == 'X':
            # 如果是'X',则arr1的第一个元素设为1,sets中存储1对应的位置为0
            arr1[0], sets[1] = 1, 0
        else:
            # 如果不是'X',则arr1的第一个元素设为-1,sets中存储-1对应的位置为0
            arr1[0], sets[-1] = -1, 0
        # 遍历str1的字符,从第二个字符开始(索引为1)
        for i in range(1, len(str1)):
            # 根据当前字符是'X'还是'Y',设置diff的值为1或-1
            diff = 1 if str1[i] == 'X' else -1
            # 更新arr1的当前位置的值,为前一个位置的值加上diff
            arr1[i] = arr1[i - 1] + diff
            # 如果arr1的当前位置的值为0,表示当前位置之前的'X'和'Y'数量相等
            if arr1[i] == 0:
                # 更新answer为当前位置加1,因为子串的起始位置到当前位置(包含当前位置)的长度是i+1
                answer = i + 1
                # 跳过当前循环的剩余部分,继续下一次循环
                continue
            # 如果arr1的当前位置的值在sets中已经存在
            if arr1[i] in sets:
                # 更新answer为当前答案与当前位置与sets中对应位置之差的较大值
                answer = max(answer, i - sets[arr1[i]])
            else:
                # 如果arr1的当前位置的值不在sets中,则将其加入sets,并记录位置
                sets[arr1[i]] = i
        # 返回最长子串的长度
        return answer
# 主函数
if __name__ == '__main__':
    # 定义一个字符串str1
    str1 = "XYXXXYYYX"
    # 实例化Solution类
    solution = Solution()
    # 打印字符串str1
    print("XY字符串:", str1)
    # 调用get_substring_longest方法,并打印最长XY出现次数相同的子字符串长度
    print("最长XY出现次数相同的子字符串长度:", solution.get_substring_longest(str1))
# 4.运行结果:
# XY字符串: XYXXXYYYX
# 最长XY出现次数相同的子字符串长度: 8
1-2、VBA:
Rem 自定义函数,功能:最长AB子串
Function GetSubstringLongest(str1 As String) As Integer
    Dim answer As Integer
    Dim arr1() As Integer
    Dim sets As Object
    Dim i As Integer
    Dim diff As Integer
    Dim key As Variant
      
    ' 初始化answer为0
    answer = 0
    ' 创建数组arr1并初始化为0
    ReDim arr1(1 To Len(str1))
    ' 初始化sets为Scripting.Dictionary对象,用于存储键值对
    Set sets = CreateObject("Scripting.Dictionary")
    ' 设置第一个字符的arr1值和sets中的键值对
    If left(str1, 1) = "X" Then
        arr1(1) = 1
        sets.Add 1, 1
    Else
        arr1(1) = -1
        sets.Add -1, 1
    End If
    ' 遍历字符串的每个字符
    For i = 2 To Len(str1)
        ' 根据当前字符设置diff的值
        diff = IIf(mid(str1, i, 1) = "X", 1, -1)
        ' 更新arr1的当前位置的值
        arr1(i) = arr1(i - 1) + diff
        ' 如果arr1的当前位置为0,则更新answer
        If arr1(i) = 0 Then
            answer = i
        End If
        ' 检查sets中是否已存在当前arr1的值
        If sets.Exists(arr1(i)) Then
            ' 更新answer为当前答案与当前位置与sets中对应位置之差的较大值
            answer = Application.WorksheetFunction.Max(answer, i - sets(arr1(i)))
        Else
            ' 如果arr1的当前值不在sets中,则将其加入sets
            sets.Add arr1(i), i
        End If
    Next i
    ' 返回最长子串的长度
    GetSubstringLongest = answer
End Function
Rem 执行程序,功能:调用自定义函数GetSubstringLongest,在立即窗口中输出结果
Sub TestRun()
    ' 声明一个变量 str1,类型为 String,用于存储待查字符串
    Dim str1 As String
    ' 声明一个变量 result,类型为 Integer,用于存储找到的最大子串长度
    Dim result As Integer
  
    ' 将给定的字符串 "XYXXXYYYX" 分配给 str1
    str1 = "XYXXXYYYX"
    ' 调用 GetSubstringLongest 函数,传入 str1,将返回的结果存储到 result 中
    result = GetSubstringLongest(str1)
    ' 使用 Debug.Print 语句打印相关信息,输出最长XY出现次数相同的子字符串长度
    Debug.Print "最长XY出现次数相同的子字符串长度:" & result
End Sub
'结果输出:
'最长XY出现次数相同的子字符串长度:8

注意:1-2中的代码需粘贴到你的VBA编辑器中,按F5执行TestRun程序,在立即窗口中输出结果。

2、相关文章:

2-1、Python-VBA编程500例-019-02(入门级) 

2-2、Python-VBA编程500例-020-01(入门级) 

2-3、Python-VBA编程500例-020-02(入门级)

2-4、Python-VBA编程500例-021(入门级)

Myelsa的Python算法之旅(高铁直达):https://myelsa1024.blog.csdn.net/article/details/136889623?spm=1001.2014.3001.5502
欢迎访问个人主页:非风V非雨-CSDN博客
欢迎志同道合者一起交流学习,我的QQ:94509325/微信:

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

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

相关文章

浅谈交直流混合微电网能量管理系统关键技术研究综述

摘要:为了提升交直流混合微电网健康有效发展,提高直流互联微电网中分布式电源的能源使用效率,提升区域微电网稳定发展,对交直流混合微电网能量管理系统关键技术进行分析和研究很有必要。文章主要从交直流混合微电网能量管理系统架…

JAVA的sort用法详解(二维数组排序,List<>排序,lambada表达式,自定义类型排序)

目录 前言&#xff1a; 一维数组降序&#xff1a; 方法1.Comparator接口&#xff1a; 代码实现&#xff1a; 方法2.Collections.reverseOrder()&#xff1a; 代码实现&#xff1a; 二维数组排序&#xff1a; 代码如下&#xff1a; List<>排序&#xff1a; 代码…

C++ 之多态虚函数原理及应用

文章目录 多态基本概念和原理虚函数的基本原理和概念虚析构和纯虚析构多重继承中的虚函数小结 多态基本概念和原理 多态的基本概念 **多态是C面向对象三大特性之一** 多态的定义 多态是一种面向对象编程概念&#xff0c;指同一个行为&#xff08;方法&#xff09;在不同的对象上…

Elastic 8.13:Elastic AI 助手中 Amazon Bedrock 的正式发布 (GA) 用于可观测性

作者&#xff1a;来自 Elastic Brian Bergholm 今天&#xff0c;我们很高兴地宣布 Elastic 8.13 的正式发布。 有什么新特性&#xff1f; 8.13 版本的三个最重要的组件包括 Elastic AI 助手中 Amazon Bedrock 支持的正式发布 (general availability - GA)&#xff0c;新的向量…

AI算法中的关键先生 - 反向转播与戴维莱姆哈特

0. 引言 机器学习的自动推导过程中有一个关键步骤&#xff0c;就是自动求解过程的参数反向传播过程&#xff0c;这个工作据说是这个人做的&#xff1a; Remembering David E. Rumelhart (1942-2011) – Association for Psychological Science – APSAPS Fellow and Charter …

极简wordpress网站模板

Pithy设计师wordpress网站模板 精练简洁的wordpress模板&#xff0c;设计师或设计工作室展示型网站模板。 https://www.jianzhanpress.com/?p6329

getshell2

怎么进后端 常见CMSgetshell 良精CMS GETSHELL1讲了很多自己看 动易CMS 学校政府 小企业很多这个CMS 网页直接插马 这是秒的方法 图片上传 编辑器漏洞这个CMS也有 怎么找编辑器F12 ctrlf editor 找到编辑器路径 利用文件目录解析漏洞将备份目录名后加上/a.asp然后备份b…

LC 101.对称二叉树

101. 对称二叉树 给你一个二叉树的根节点 root &#xff0c; 检查它是否轴对称。 示例 1&#xff1a; 输入&#xff1a; root [1,2,2,3,4,4,3] 输出&#xff1a; true 示例 2&#xff1a; 输入&#xff1a; root [1,2,2,null,3,null,3] 输出&#xff1a; false 提示&#x…

MySQL高阶SQL语句(二)

文章目录 MySQL高阶SQL语句&#xff08;二&#xff09;一、MySQL常用查询1、子查询1.1 语法1.1.1 结合select语句查询1.1.2 结合insert语句查询1.1.3 结合update语句查询1.1.4 结合delete语句查询1.1.5 在in前面添加not1.1.6 exists关键字 2、别名 二、MySQL视图1、视图介绍1.1…

vue2 父组件引入子组件

前言 感觉自己基础知识不是很扎实&#xff0c;在项目中好好学习。记录一下。 vue其中比较一个好用的就是一个页面中内容过多。为了更好的操作以及管理代码。可以将一个页面分成好几个部分&#xff0c;最后整合到一个一起。 例如&#xff1a; 京东这个页面&#xff0c;其实可…

04-JavaScript函数

函数&#xff08;重点&#xff09; 1.为什么使用函数? 用函数来解决代码重用的问题。 2.函数的意义 函数其实就是封装&#xff0c;把可以重复使用的代码放到函数中&#xff0c;如果需要多次使用同一段代码&#xff0c;就可以把封装成一个函数。这样的话&#xff0c;在你需…

报错there is no HDFS_NAMENODE_USER defined

在Hadoop安装目录下找到sbin文件夹&#xff0c;修改里面的四个文件 1、对于start-dfs.sh和stop-dfs.sh文件&#xff0c;添加下列参数&#xff1a; HDFS_DATANODE_USERroot HDFS_DATANODE_SECURE_USERhdfs HDFS_NAMENODE_USERroot HDFS_SECONDARYNAMENODE_USERroot 2、对于st…

TCPView下载安装使用教程(图文教程)超详细

「作者简介」&#xff1a;CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者 「推荐专栏」&#xff1a;更多干货&#xff0c;请关注专栏《网络安全自学教程》 TCPView是微软提供的一款「查看网络连接」和进程的工具&#xff0c;常用来查看电脑上的TCP/UDP连接…

我与电源 3 - 电源反激战

老同志看到标题就能猜到,我今天要讲什么。 在我的技术栈里面,对于交流电接触的实在不多,因此对于反激电源这个鬼东西,我一开始也是非常模糊的。 2014 年的时候,我来到了一家做平衡车的企业,承担的任务是开发独轮平衡车,彼时公司只有两轮平衡车业务,那时候的两轮平衡车…

正弦实时数据库(SinRTDB)的使用(4)-快照查询

前文已经将松果实时数据库的安装、创建点表、创建测点、接入OPC DA的数据进行了介绍&#xff0c;没有了解的可以先看如下博客&#xff1a; 正弦实时数据库(SinRTDB)的安装 正弦实时数据库(SinRTDB)的使用(1)-使用数据发生器写入数据 正弦实时数据库(SinRTDB)的使用(2)-接入O…

倍压器电路原理及仿真

倍压器是利用二极管单向导通的特性和电容两端电压不能突变且可以存储能量的特性&#xff0c;使得能量逐步往后级输送&#xff0c;同时线路上的电压也逐渐升高。因此&#xff0c;它可以实现将较低的交流电压转换成一个较高的直流电压。根据倍压的原理&#xff0c;有二倍压、三倍…

喜讯!云起无垠入围2023年度中国高科技高成长企业系列榜单

近期&#xff0c;由【第一新声】与【天眼查】共同发起的“数字未来”系列评选活动揭晓了2023年度中国高科技高成长企业入围榜单。在此次评选中&#xff0c;云起无垠与腾讯安全、绿盟科技、奇安信、深信服、启明星辰、天融信、亚信安全、安恒信息等安全厂商一同入围网络安全领域…

KubeSphere简单介绍及安装使用

KubeSphere 概述 官网地址&#xff1a;https://kubesphere.io/zh/ 什么是 kubesphere KubeSphere 是一个开源的多云容器管理平台&#xff0c;旨在简化企业级 k8s 集群的部署、管理和运维。它提供了一个可视化的管理界面&#xff0c;帮助用户更轻松地管理和监控 k8s 集群&…

Nginx部署VUE3项目

build 打包生成 dist 上传至服务器版本&#xff1a;nginx1.24&#xff0c;dist放置根目录下html下 location / {#项目打包生成的静态文件所在路径 配置要打开的资源的根目录的地址&#xff0c;是以 nginx 下的 html 文件夹中dist为根目录来查找的root html/dist;#默认主页in…

前端学习<二>CSS基础——06-CSS盒模型详解

盒子模型 前言 盒子模型&#xff0c;英文即box model。无论是div、span、还是a都是盒子。 但是&#xff0c;图片、表单元素一律看作是文本&#xff0c;它们并不是盒子。这个很好理解&#xff0c;比如说&#xff0c;一张图片里并不能放东西&#xff0c;它自己就是自己的内容。…