溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python錯(cuò)位鍵盤、單詞長(zhǎng)度、字母重排的方法

發(fā)布時(shí)間:2022-03-07 16:38:26 來(lái)源:億速云 閱讀:213 作者:iii 欄目:開(kāi)發(fā)技術(shù)

今天小編給大家分享一下Python錯(cuò)位鍵盤、單詞長(zhǎng)度、字母重排的方法的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來(lái)了解一下吧。

一、錯(cuò)位鍵盤

問(wèn)題描述

在我們打字的時(shí)候,往往會(huì)因?yàn)槭终`將A敲成S,將S敲成D

現(xiàn)在有一位程序員由于手誤輸入了一行字符串 請(qǐng)憑借你聰明的大腦將其還原 (鍵盤上的字符順序:"`1234567890-=QWERTYUIOP[]\ASDFGHJKL;'ZXCVBNM,./")

樣例輸入:O S, GOMR YPFSU/

樣例輸出:I AM FINE TODAY

問(wèn)題分析

這類的問(wèn)題有事后想到的就是進(jìn)行字符的替換,但是一個(gè)鍵盤上字符那么多逐個(gè)替換的話非常的費(fèi)時(shí)費(fèi)力于是我們可以進(jìn)行一個(gè)下標(biāo)數(shù)組的編排,用于記錄字符在字符串中的位置,而為了不必要的轉(zhuǎn)換我們不妨將下標(biāo)數(shù)組開(kāi)辟到255個(gè)這樣每一種字符的ASCII值就可以直接作為下標(biāo)數(shù)組的下標(biāo)拿到他在原來(lái)字符串的索引。

然后根據(jù)輸入可以知道,輸入的有空格,給定的鍵盤內(nèi)沒(méi)有空格,所以需要進(jìn)行分詞處理。在Python中分詞有極為簡(jiǎn)便的方法,在C語(yǔ)言中可以開(kāi)辟一個(gè)字符型指針數(shù)組,用于存儲(chǔ)每一段單詞,處理方式與單詞的平均長(zhǎng)度無(wú)異??梢韵韧驴纯?。分完詞之后可以迭字符型指針數(shù)組。然后按序列輸出。輸出的時(shí)候先拿字符做下標(biāo)取原字符串中的索引,然后再拿索引-1去原字符中取字符。注意輸出時(shí)候的格式。

代碼實(shí)現(xiàn)

老規(guī)矩先上運(yùn)行結(jié)果:

Python錯(cuò)位鍵盤、單詞長(zhǎng)度、字母重排的方法

代碼如下:

import sys
s=sys.stdin.readline().strip().split()
indexarr=[0]*255
# 將所有數(shù)據(jù)存放進(jìn)一個(gè)數(shù)組,將鍵盤上相鄰的兩個(gè)字母在數(shù)組中以索引的形式相連
mystr="`1234567890-=QWERTYUIOP[]\\ASDFGHJKL;'ZXCVBNM,./"
# 將每一位字母的索引存儲(chǔ)起來(lái)。供以后遍歷輸入的數(shù)據(jù)使用
for i in range(len(mystr)):
    indexarr[ord(mystr[i])]=i

flag=True
#遍歷輸入的n段字符串
for line in s:
    if flag:
        flag=False
        for i in line:
            print(mystr[indexarr[ord(i)]-1],end="")  
    else:
        print(" ",end="")
        for i in line:
            print(mystr[indexarr[ord(i)]-1],end="")

二、單詞的平均長(zhǎng)度

使用c語(yǔ)言做的話先進(jìn)行空格統(tǒng)計(jì),如果空格后面不為空格就進(jìn)行單詞數(shù)加1
如果空格后面依舊是空格向下遍歷,如果一個(gè)位置不為空格就進(jìn)行字母數(shù)加1
最終要將單詞數(shù)額外加1,因?yàn)槭孜矄卧~循環(huán)的時(shí)候只統(tǒng)計(jì)進(jìn)去了一個(gè)。

問(wèn)題描述

輸入若干個(gè)單詞,單詞只包含字母,每個(gè)單詞由一個(gè)或多個(gè)空格組成

輸出單詞的平均長(zhǎng)度

樣例輸入:qwe qwe qwe

樣例輸出:3.0

問(wèn)題分析

對(duì)字符串進(jìn)行分詞,然后求每一個(gè)字串的長(zhǎng)度,再將長(zhǎng)度和除以單詞的個(gè)數(shù)

代碼實(shí)現(xiàn)

老規(guī)矩先上運(yùn)行結(jié)果:

Python錯(cuò)位鍵盤、單詞長(zhǎng)度、字母重排的方法

代碼如下:

import sys
num=0
n=0
# 這里使用strip()去除輸入的末尾換行符
# 使用split()進(jìn)行字符串分段最后得到的是一個(gè)列表形式
mystr=sys.stdin.readline().strip().split()

for i in mystr:
    num+=len(i)
    n+=1
print(num/n)

三、字母重排

問(wèn)題描述

輸入一個(gè)字典(*****結(jié)尾),然后再輸入若干單詞。每輸入一個(gè)單詞w,你都需要 在字典中找出所有可以用w的字母重排后得到的單詞,并按照字典序從小到大的順序在一 行中輸出(如果不存在,輸出:0。輸入單詞之間用空格或空行隔開(kāi),且所有輸入單詞都由 不超過(guò)6個(gè)小寫(xiě)字母組成。注意,字典中的單詞不一定按字典序排列。

樣例輸入:

第一行 tarp given score refund only trap work earn course pepper part

第二行 resco nfudre aptr sett oresuc

樣例輸出:

course part refund score tarp trap

問(wèn)題分析

給出一個(gè)字典,所以我們?cè)谶M(jìn)行查找的時(shí)候可以先將字典進(jìn)行處理,然后依照字典的標(biāo)準(zhǔn)進(jìn)行查詞

這里我們可以先對(duì)字典進(jìn)行排序得到首字母有序的字典,然后對(duì)字典中每一個(gè)元素進(jìn)行排序。 對(duì)要查詢的子串進(jìn)行排序,然后遍歷有序字典進(jìn)行查找,找到直接輸出(也就是說(shuō)將標(biāo)準(zhǔn)的字典按 一定的方式處理,然后將所要查的詞經(jīng)過(guò)相同的轉(zhuǎn)換后與字典進(jìn)行比對(duì))

代碼實(shí)現(xiàn)

老規(guī)矩先上運(yùn)行結(jié)果:

Python錯(cuò)位鍵盤、單詞長(zhǎng)度、字母重排的方法

代碼如下:

import sys
# 元字典序字符串
mydic=list(sys.stdin.readline().strip().split())
mydic=sorted(mydic)
words=sys.stdin.readline().strip().split()
# 排序后的字符串
newdic=[]
newwords=[]
for i in mydic:
    # 字符串不可以直接排序,先轉(zhuǎn)換成字典,然后進(jìn)行排序
    newdic.append("".join(sorted(i)))

for i in words:
    newwords.append("".join(sorted(i)))
flag=False
i=0
while i<len(newdic):
    if newdic[i] in newwords:
        if not flag:
            print(mydic[i],end="")
            flag=True
        else:
            print(" ",mydic[i],end="")
    i+=1

if not flag:
    print(0)

四、Tex括號(hào)問(wèn)題

問(wèn)題描述

有一篇文章,在撰稿的時(shí)候,沒(méi)有按照指定格式編排,現(xiàn)在需要將包含'' 的標(biāo)點(diǎn)符號(hào)轉(zhuǎn)換成為 只有中文雙引號(hào)的文章“”

樣例輸入:"anksdn,'dasd,“hhihi”

樣例輸出:“anksdn,”dasd,“hhihi”

問(wèn)題分析

這里與前面提到的燈光模擬非常的類似,只需要記性標(biāo)記位的整頓就好

可以設(shè)計(jì)一個(gè)標(biāo)記flag,當(dāng)flag為True時(shí)遇見(jiàn)"進(jìn)行左引號(hào)“的輸出然后

立即將標(biāo)記變?yōu)榕c其相反的值當(dāng)flag為false時(shí)遇見(jiàn)"立即進(jìn)行右引號(hào)輸出。

然后將flag標(biāo)記為True

代碼實(shí)現(xiàn)

老規(guī)矩先上運(yùn)行結(jié)果:

Python錯(cuò)位鍵盤、單詞長(zhǎng)度、字母重排的方法

代碼如下:

import sys
s=sys.stdin.readline().strip()
flag=True
for i in s:
    if i=="'" or i=="\"":
        if flag:
            print("“",end="")
        else:
            print("”",end="")
        flag=not flag
        continue
    print(i,end="")

以上就是“Python錯(cuò)位鍵盤、單詞長(zhǎng)度、字母重排的方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI