字符串解码

原创博客,转载请注明出处!
eg:
ss=2[abc]3[cd]ef   return:abcabccdcdcdef
ss=3[a2[c]]2[a]    return:accaccaccaa
ss=10[abc]3[cd]ef return:abcabcabcabcabcabcabcabcabcabccdcdcdef
如何实现前面例子的效果呢?

首先分析s='2[abc]',要得到字符串'abcabc'非常容易
In [102]: int(s[0])*s[2:5]
Out[102]: 'abcabc'
其中,s[2:5]中的2代表‘[’之后的位置,5代表‘]’的位置,那么我就有启发了,如果我能得到‘[]’之间的内容以及‘[’前面的数字,就可以完成一个中括号之间的字符串相乘了。
1、首先找到第一个匹配的中括号[],可以遍历整个字符串。找到一个‘[’就用index_1记录下来,继续遍历,当下一个'['出现的时候,index_1的值会更新,直到找到‘]’记录位置index_2,此时的‘index_1和index_2就是要找的第一个'[]'。
2、获取index_1到index_2的内容
3、获取index_1前面的数字,注意数字可能是很多位数。从index_1的前一个开始遍历,如果是数字就加入字符串num里面,注意要加在字符串的前面,直到第一个非数字出现,则跳出for循环。
具体代码如下:
def onestr(ss):  
    for i in range(len(ss)):
        if ss[i] == '[':
            index_1=i #记录方括号开始的位置
            #print(index_1)
        if ss[i]==']':
            index_2=i #记录方括号结束的位置
            temp=ss[index_1:index_2+1] #取出方括号开始以及结束的位置
            #取出方括号[前面的数字,由于数字可能为多位,所以用while循环实现
            num=''
            j=1
            while(1):
     #从[的前一个位置开始找,直到不是数字为止
                if ss[index_1-j].isdigit():
                    num=ss[index_1-j]+num #num为字符串类型
                    j=j+1
                    continue
                else:
                    break
            break
    return temp,num
onestr('2[abc]3[cd]ef')
一次操作的结果为:
temp,num='[abc]','2'
将abc和2相乘的结果,替换掉源字符串2[abc]
ss=ss.replace(num+str_temp,int(num)*str_temp.lstrip('[').rstrip(']'))
由于temp='[abc]',直接相乘会把[]符号也乘进去,因此需要去掉两边的符号。
ss=abcabc3[cd]ef
一个方括号需要一次相乘,n个方括号就需要n次相乘,因此一个while循环,循环条件为方括号的个数,即可实现整个字符串的替换。
ss=input()
print(ss)
i=0
N=ss.count('[')
while(i<N):
     str_temp,num=onestr(ss)     ss=ss.replace(num+str_temp,int(num)*str_temp.lstrip('[').rstrip(']'))     i=i+1
print(ss)

程序代码:

def onestr(ss):  
    for i in range(len(ss)):
        if ss[i] == '[':
            index_1=i #记录方括号开始的位置
        if ss[i]==']':
            index_2=i #记录方括号结束的位置
            temp=ss[index_1:index_2+1] #取出方括号开始以及结束的位置
            num=''
            j=1
            while(1):
                if ss[index_1-j].isdigit(): #从[的前一个位置开始找,直到不是数字为止
                    num=ss[index_1-j]+num #num为字符串类型
                    j=j+1
                    continue
                else:
                    break
            break
    return temp,num
ss=input()
print(ss)
i=0
N=ss.count('[')
while(i<N):
    str_temp,num=onestr(ss)
    ss=ss.replace(num+str_temp,int(num)*str_temp.lstrip('[').rstrip(']'))
    i=i+1
print(ss)

字符串解码DecodeString的更多相关文章

  1. LeetCode 394. 字符串解码(Decode String) 44

    394. 字符串解码 394. Decode String 题目描述 给定一个经过编码的字符串,返回它解码后的字符串. 编码规则为: k[encoded_string],表示其中方括号内部的 enco ...

  2. Java实现 LeetCode 394 字符串解码

    394. 字符串解码 给定一个经过编码的字符串,返回它解码后的字符串. 编码规则为: k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次.注意 k ...

  3. [PHP]对Json字符串解码返回NULL的一般解决方案

    ---------------------------------------------------------------------------------------------------- ...

  4. unicode字符串解码显示

    # encoding: utf-8 ''' unicode字符串解码显示 ''' import sys reload(sys) sys.setdefaultencoding('utf-8') a = ...

  5. [Swift]LeetCode394. 字符串解码 | Decode String

    Given an encoded string, return it's decoded string. The encoding rule is: k[encoded_string], where ...

  6. [Leetcode]394.字符串解码

    题目与解释 给定一个经过编码的字符串,返回它解码后的字符串. 编码规则为: k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次.注意 k 保证为正 ...

  7. Q394 字符串解码

    给定一个经过编码的字符串,返回它解码后的字符串. 编码规则为: k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次.注意 k 保证为正整数. 你可 ...

  8. 394 Decode String 字符串解码

    给定一个经过编码的字符串,返回它解码后的字符串.编码规则为: k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次.注意 k 保证为正整数.你可以认 ...

  9. LeetCode 394:字符串解码 Decode String

    题目: 给定一个经过编码的字符串,返回它解码后的字符串. Given an encoded string, return its decoded string. 编码规则为: k[encoded_st ...

随机推荐

  1. Bitbucket 触发内网 Jenkins Build

    为了保证安全性多数的持续集成系统都会部署在公司内部的局域网中,这样如果代码部署在 Bitbucket 等环境中就只能通过轮询的方式来触发 Build.那么有没有办法通过 Bitbucket 的 Web ...

  2. PowerShell脚本—停止占用8080端口的进程

    $str = netstat -ano $list = $str.Split('\n') ; $i -lt $list.Length; $i++) { $item_list = [System.Tex ...

  3. java.sql.Exception:setString 只能处理少于 32766 个字符的字符串

    java.sql.Exception:setString 只能处理少于 32766 个字符的字符串 解决方式是 : 升级ojdbc的版本,   将原来的 ojdbc14_10.2.0.2.0.jar ...

  4. 基本的maven的命令行命令

    1.创建简单的maven 的web项目 mvn archetype:create 举例:mvn archetype:create -DgroupId=com.demo.app -DartifactId ...

  5. iOS开发-AFNetworking参数和多文件同时上传【多文件上传】

    1. 前言 在项目开发中,我们经常需要上传文件,例如:上传图片,上传各种文件,而有时也需要将参数和多个文件一起上传,不知道大家的项目中遇到了没有,我在最近的项目中,就需要这样的一个功能:同时上传参数. ...

  6. python进阶之Socket 网络编程

     一:网络编程介绍   自从互联网诞生以来,现在基本上所有的程序都是网络程序,很少有单机版的程序了. 计算机网络就是把各个计算机连接到一起,让网络中的计算机可以互相通信.网络编程就是如何在程序中实现两 ...

  7. mybatis快速入门(五)

    今天写写user表和orders表的mybatis的高级映射,一对一映射和一对多映射 1.创建一个orders.java文件 1.1一对一映射,一条订单对应一个用户 package cn.my.myb ...

  8. AngularJS -- 提供者(Providers)

    点击查看AngularJS系列目录 转载请注明出处:http://www.cnblogs.com/leosx/ 每个Web应用程序都是有多个对象组合.协作来完成任务的.这些对象需要被实例化,并且连接在 ...

  9. [js高手之路] html5新增的定时器requestAnimationFrame实战进度条

    在requestAnimationFrame出现之前,我们一般都用setTimeout和setInterval,那么html5为什么新增一个requestAnimationFrame,他的出现是为了解 ...

  10. kbhit()

    kbhit() 非阻塞的响应键盘输入时间   C++函数 功能和返回值:检查是否有键盘输入 ,有返回非0 ,无返回0 int khbit(void) 头文件: #include<conio.h& ...