|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
第一道:【问题描述】
有一行电文,已按下面规律译成密码:
A--Z a--z
B--Y b--y
C--X c--x
......
即第1个字母变成第26个字母,第i个字母变成第(26-i+1)个字母; 非字母字符不变。编写程序把密码译回原文,并输出密码和原文。
【输入形式】
输入一串密码
【输出形式】
首先输出密码,然后换行后输出原文
【样例输入】
4sdf&13TBD
【样例输出】
4sdf&13TBD
4hwu&13GYW
第二道:【问题描述】
本题目要求读入一个字符串,输出字符串的最长数字子串。
【输入形式】
输入一个字符串
【输出形式】
输出最长数字子串,若有多个最长数字子串输出最后一个,若字符串无数字字符,则输出“No digits”。
【输入样例】
sdffsd123werrer456fgdgdg1dfgdf12
【样例输出】
456
第三道:【问题描述】
如果字符串包含连续相同字符的子串,那么我们可以使用步长压缩法来压缩字符串。这种方法的原理是将连续相同字符的子串使用字符加上连续出现的个数(忽略个数为1的情况)来代替 。 例 如:字 符 串“bbbbbbaaaaacyyyyyywwdddddddddxxxxyddd” 可 以 压 缩 为“b6a5cy6w2d9x4yd3”。请编写程序,从键盘输入一个字符串放入一个 string对象中,并将压缩结果放入另外一个 string 对象中,并输出它。
【输入形式】
输入只包含大小写英文字符的字符串,连续相同的字符个数不超过9。
【输出形式】
经过压缩的字符串
【样例输入1】
aaacdbeedkksss
【样例输出1】
a3cdbe2dk2s3
不建议你在论坛来求答案,希望你能自己先做,遇到问题在贴代码来论坛提问:
- # 第一题
- old_password, new_password = input(), ''
- for i in old_password:
- if 65 <= ord(i) <= 90:
- i = chr(155 - ord(i))
- elif 97 <= ord(i) <= 122:
- i = chr(219 - ord(i))
- new_password += i
- print(old_password)
- print(new_password)
- # 第二题
- string = input()
- result, record = '', [0, 0]
- for i in range(len(string)):
- if string[i].isdigit():
- result += string[i]
- elif result:
- if len(result) >= record[1] - record[0]:
- record = [i - len(result),i]
- result = ''
- print(string[record[0]:record[1]])
- # 第三题
- sting = input()
- i, result = 0, ''
- while len(sting) > i:
- index = 1
- result += sting[i]
- while index+i < len(sting) and sting[i] == sting[i + index]:
- index += 1
- if index != 1:
- result += str(index)
- i += index
- print(result)
复制代码
|
|