一個(gè)字符串的某一個(gè)子串中可能含有重復(fù)出現(xiàn)的字符,如字符串“abab”的其中一個(gè)子串“aba”就含有2個(gè)重復(fù)出現(xiàn)的字符“a”。小明設(shè)計(jì)了一個(gè)尋找無重復(fù)字符的最長子串的算法,具體步驟如下:
步驟1:初始化最長無重復(fù)字符子串的長度 maxn=0。
步驟2:初始化字符串長度n,字符串索引left=0,right=0。
步驟3:判斷right是否超過字符串長度,若超過則執(zhí)行步驟4,否則判斷字符串從位置left到位置right是否有重復(fù)字符:若存在重復(fù),則將索引left的值修改為存在重復(fù)字符索引值+1;若不存在重復(fù),則判斷該子串長度是否比maxn大,若比maxn大,則更新maxn的值。修改right的值。重復(fù)步驟3。
步驟4:輸出maxn的值。
實(shí)現(xiàn)上述功能的程序如下,請?jiān)跈M線處填入合適的代碼。
#在字符串s中查找第一次出現(xiàn)字符c的位置
def search(s,c):
for i in range(len(s)):
if ①:
return i
s=input(“請輸入字符串:“)
maxn=0
left=0
right=0
②
while right<n:
if s[right]in s[left:right]:
k=search(s[left:right],s[right])
③
else:
if right-left+1>maxn:
maxn=right-left+1
right+=1
print(maxn)
【考點(diǎn)】編輯事件處理過程的代碼.
【答案】見試題解答內(nèi)容
【解答】
【點(diǎn)評】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/4/20 14:35:0組卷:1引用:1難度:0.3
相似題
-
1.學(xué)校舉辦了“語文作文現(xiàn)場賽”,參賽同學(xué)成績存儲在文本文件“gra.jye.ai”中,如左圖所示(每一行記錄一位同學(xué)的姓名和成績,以“:”分隔)。陳老師利用Python程序?qū)ψ魑某煽冞M(jìn)行處理,統(tǒng)計(jì)出各個(gè)分?jǐn)?shù)等級的人數(shù),并輸出結(jié)果。程序運(yùn)行界面如右圖所示。
實(shí)現(xiàn)上述功能的Python程序如下,請?jiān)趧澗€處填入合適的代碼。發(fā)布:2024/12/17 2:0:1組卷:6引用:2難度:0.3 -
2.有如下Python程序段:
執(zhí)行該程序段,輸入字符串“abcdefg”,則輸出的結(jié)果是( ?。?/h2>發(fā)布:2024/12/20 6:30:1組卷:2引用:3難度:0.4 -
3.試題描述的內(nèi)容:
一個(gè)單窗體VB程序的運(yùn)行界面如圖所示。下列說法正確的是( )
(1)窗體內(nèi)有1個(gè)按鈕
(2)窗體內(nèi)有2個(gè)文本框
(3)窗體內(nèi)有3個(gè)標(biāo)簽
(4)該窗體的標(biāo)題(Caption)屬性值是“加法計(jì)算器”發(fā)布:2024/12/20 20:0:2組卷:1引用:1難度:0.6
把好題分享給你的好友吧~~