2021-5-8字符串作业

本文通过多个实例介绍了如何使用Python进行字符串操作,包括字符提取、转换、统计等实用技巧。
  1. 输入一个字符串,打印所有奇数位上的字符(下标是1,3,5,7…位上的字符)

    例如: 输入**'abcd1234 ’ ** 输出**‘bd24’**

    str1 = 'abcd1234 '
    str2 = [x for x in str1]
    print(''.join(str2[1::2]))
    
  2. 输入用户名,判断用户名是否合法(用户名长度6~10位)

user = input('请输入用户名:')
if 10 >= len(user) >= 6:
    print('用户名长度合法')
else:
    print('用户名长度不合法')
  1. 输入用户名,判断用户名是否合法(用户名中只能由数字和字母组成)

    例如: ‘abc’ — 合法 ‘123’ — 合法 ‘abc123a’ — 合法

user = input('请输入用户名:')
for x in user:
    if '0' <= x <= '9' or 'a' <= x <= 'z' or 'A' <= x <= 'Z':
        continue
    else:
        print('用户名长度不合法')
        break
else:
    print('用户名长度合法')
  1. 输入用户名,判断用户名是否合法(用户名必须包含且只能包含数字和字母,并且第一个字符必须是大写字母)

    例如: ‘abc’ — 不合法 ‘123’ — 不合法 ‘abc123’ — 不合法 ‘Abc123ahs’ — 合法

user = input('请输入用户名:')
if 'A' <= user[0] <= 'Z':
    count = 0
    for x in user[1:]:
        if not ('0' <= x <= '9' or 'a' <= x <= 'z' or 'A' <= x <= 'Z'):
            print('不合法')
            break
        else:
            if '0' <= x <= '9':
                count += 1
    else:
        if count == 0:
            print('不合法')
        else:
            print('合法')

else:
    print('不合法')
  1. 输入一个字符串,将字符串中所有的数字字符取出来产生一个新的字符串

    例如:输入**‘abc1shj23kls99+2kkk’** 输出:'123992’

str2 = 'abc1shj23kls99+2kkk'
result2 = ''.join([x for x in str2 if '0' <= x <= '9' ])
print(result2)
  1. 输入一个字符串,将字符串中所有的小写字母变成对应的大写字母输出 (用upper方法和自己写算法两种方式实现)

    例如: 输入**‘a2h2klm12+’ ** 输出 'A2H2KLM12+'

str3 = 'a2h2klm12+'
print(str3.upper())


str3 = 'a2h2klm12+'
new_str3 = ''
for x in str3:
    if 'a' <= x <= 'z':
        new_str3 += chr(ord(x) - 32)
    else:
        new_str3 += x
print(new_str3)

# 方法二
print(''.join(chr(ord(x) - 32) if x.islower() else x for x in str3))
  1. 输入一个小于1000的数字,产生对应的学号

    例如: 输入**‘23’,输出’py1901023’** 输入**‘9’, 输出’py1901009’** 输入**‘123’,输出’py1901123’**

str = input('请输入一个小于1000的数字:')
str1 = 'py1901'
str2 = ''
for x in str:
    if len(str) == 1:
        str2 = '00' + str
    elif len(str) == 2:
        str2 = '0' + str
    elif len(str) == 3:
        str2 = str
    else:
        print('请输入一个小于1000的数字:')
print(str1 + str2)

#方法二
num = 9
num_str = str(num)
count = len(num_str)
print('py1901' + '0'*(3-count)+num_str)
  1. 输入一个字符串,统计字符串中非数字字母的字符的个数

    例如: 输入**‘anc2+93-sj胡说’** 输出:4 输入**’===’** 输出:3

str = input('请输入一个字符串:')
str1 = []
for x in str:
    if '0' <= x <= '9' or 'a' <= x <= 'z' or 'A' <= x <= 'Z':
        pass
    else:
        str1 += x
print(len(str1))

# 方法二
str1 = 'anc2+93-sj胡说'
count = 0
for x in str1:
    if not (x.isdigit() or x.islower() or x.isupper()):
        count +=1
print(count)
  1. 输入字符串,将字符串的开头和结尾变成’+’,产生一个新的字符串

    例如: 输入字符串**‘abc123’, 输出’+bc12+’**


str = input('请输入一个字符串:')
str1 = ''.join([x for x in str[1:-1:]])
print('+' + str1 + '+')
  1. 输入字符串,获取字符串的中间字符

例如: 输入**‘abc1234’** 输出:‘1’ 输入**‘abc123’** 输出**‘c1’**

str = input('请输入一个字符串:')
str1 = [x for x in range(len(str))]
str2 = ''
if len(str1) % 2 != 0:
    str2 = str[len(str)//2]
if len(str1) % 2 == 0:
    str2 = str[len(str) // 2-1] + str[len(str) // 2]
print(str2)
  1. 写程序实现字符串函数find/index的功能(获取字符串1中字符串2第一次出现的位置)

例如: 字符串1为:how are you? Im fine, Thank you! , 字符串2为:you, 打印8

str1 = 'how are you? Im fine, Thank you!'
print(str1.find('you'))

  1. 获取两个字符串中公共的字符

例如: 字符串1为:abc123, 字符串2为: huak3 , 打印:公共字符有:a3

str1 = 'abc123'
str2 = 'huak3'
set1 = set(str1) & set(str2)
str3 = ''.join(set1)
print(str3)

### PTA 7-5 字符串删除操作解题思路 对于PTA 7-5字符串删除操作,主要涉及两种类型的题目:一种是删除特定字符;另一种是删除子串。以下是针对这两种情况的具体分析。 #### 删除指定字符 当目标是从给定字符串中移除所有出现的某个特定字符时,可以通过遍历整个字符串并跳过不需要保留的目标字符来实现这一功能[^1]。具体做法如下: ```cpp #include<string.h> void delchar(char* str, char c){ int i,j,n; n=strlen(str); for(i=0;i<n;i++){ if(str[i]==c){ for(j=i;j<n;j++)// 将后续字符前移覆盖当前被删除的位置 str[j]=str[j+1]; i--; // 调整索引以重新检查当前位置的新字符 } } str[i]='\0'; // 结束处理后的字符串 } ``` 此方法通过逐一遍历源字符串`str`中的每一个位置,并在遇到匹配项时调整剩余部分的内容向前移动一位,从而达到去除该字符的效果。 #### 删除子串 如果任务变为从较长的字符串里找出所有的短序列(即子串),并将这些片段全部清除,则需要更复杂的逻辑。通常采用KMP算法或其他模式匹配技术找到所有符合条件的小段文字,再依次执行替换或截断动作[^3]。 虑到效率问题,在实际编程过程中也可以利用标准库函数简化流程,比如C++里的`std::string::erase()`配合上`find()`来进行定位和消除工作。下面是一个简单的例子展示如何高效地完成这项任务: ```cpp #include<iostream> #include<algorithm> using namespace std; int main(){ string s1,s2; getline(cin,s1);getline(cin,s2); size_t pos = 0; while((pos=s1.find(s2,pos))!=string::npos){ s1.erase(pos,s2.length()); } cout<<s1<<endl; return 0; } ``` 上述代码展示了怎样读取两个字符串作为输入参数,并不断寻找`s2`在`s1`内的起始下标直至找不到为止,期间每发现一次就立即调用成员函数`erase()`将其抹去。 综上所述,无论是单个字符还是连续的一组字符组成的子串,都可以依据实际情况选用合适的方法进行有效的清理作业
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值