[蓝桥杯2022初赛] 消除游戏

题目:

来源:P2045 - [蓝桥杯2022初赛] 消除游戏 - New Online Judge (ecustacm.cn)

 分析:

首先,可以明确一件事情,不管怎么删除,都要在遍历完字符串后在删除。然后,新生成的字符串再进行重复操作。

题目中虽然给了次数,但明显是骗人的,只需要判断字符串不再改变就可以停止了。

代码实现:

import time
import random

def generate_random_str(randomlength=16):
  """
  生成一个指定长度的随机字符串
  """
  random_str =''
  base_str ='abcdefghigklmnopqrstuvwxyz'
  length =len(base_str) -1
  for i in range(randomlength):
      random_str += base_str[random.randint(0, length)]
  return random_str

def find(x,arr):
    left = 0
    right = len(arr)
    mid = -1
    while (left<right):
        mid = (left+right)//2
        if arr[mid]==x:
            return False
        elif flag[mid]<x:
            left = mid+1
        else:
            right = mid
    return True

#s = input()
s = generate_random_str(10**5)
start = time.time() #记录时间,下面同理,测试用的
lst = list(s)
flag = []
while True:
    isChange = False
    for i in range(1,len(lst)-1):
        if (lst[i]==lst[i-1] and lst[i]!=lst[i+1]):
            flag.append(i)
            flag.append(i+1)
        if (lst[i]!=lst[i-1] and lst[i]==lst[i+1]):
            flag.append(i-1)
            flag.append(i)
    if len(flag)==0:
        break
    tem = []
    # flag.sort() # 不需要排序,插入的时候已经排好序了
    for j in range(len(lst)):
        if find(j,flag):
            tem.append(lst[j])
    lst = tem
    flag = []

if (len(lst)==0):
    print("EMPTY")
else:
    print("".join(lst)) 
    
end = time.time()
print(end-start)

分析:

随机字符串试了试,估计数据量一大就会寄掉,希望大神帮帮忙。

后面同学说用系统自带的pop()定位删除,不过会有重复删除的情况,我懒得再写了,有兴趣的可以试试看。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值