蓝桥杯-本质上升序列

没有白走的路,每一步都算数🎈🎈🎈

题目描述:

小蓝特别喜欢单调递增的事物

在一个字符串中如果取出若干个字符,按照在原来字符串中的顺序排列在一起,组成的新的字符串如果是单调递增的,那么则称这个字符串为一为一个单调递增子序列。但是对于lanqiao字符串,

单调子序列可以有l,a,n,q,i,o;

ao,io,q,nq,no,ai,aq,an,aio,ano,anq;

lo,ln,lq,lnq

但是,第一个‘a’能够和‘o’组成一个单调递增子序列,倒数第一个‘a’也能和‘o’组成一个子序列,我们称这样的序列本质上是相同的。求问总共有多少本质不同的单调上升子序列

输入描述:

输入一个字符串s,字符串总共有4行,每行50个字母,总共有200个字母。试求这个字符串的本质上升序列总共有多少?

样例输入输出:

样例输入:

tocyjkdzcieoiodfpbgcncsrjbhmugdnojjddhllnofawllbhf iadgdcdjstemphmnjihecoapdjjrprrqnhgccevdarufmliqij gihhfgdcmxvicfauachlifhafpdccfseflcdgjncadfclvfmad vrnaaahahndsikzssoywakgnfjjaihtniptwoulxbaeqkqhfwl

算法设计:

从后往前找,一个字符一个字符累加。遇到不相同的并且后面字母比前面大的就累加,遇到相同的则需要减去相同的字符串。

import os
import sys
s = "tocyjkdzcieoiodfpbgcncsrjbhmugdnojjddhllnofawllbhfiadgdcdjstemphmnjihecoapdjjrprrqnhgccevdarufmliqijgihhfgdcmxvicfauachlifhafpdccfseflcdgjncadfclvfmadvrnaaahahndsikzssoywakgnfjjaihtniptwoulxbaeqkqhfwl"
dp = [0]*200
n = len(s)
cnt = 0
for i in range(n-1,-1,-1):
    dp[i] = 1
    for j in range(i+1,n):
        if s[i]<s[j]:
            dp[i]+=dp[j]
        elif s[i]==s[j]:
            dp[i]-=dp[j]
    cnt+=dp[i]
print(cnt)

每日一句

摘自《平凡的世界》:

人生啊,是这样不可预测,没有永恒的痛苦,也没有永恒的幸福,生活像流水一般,有时是那么平展,有时又是那么曲折。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Li&&Tao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值