牛客网华为机试在线训练(二)

本文介绍了牛客网上针对华为机试的Python编程训练,涵盖数字颠倒、字符串反转、句子逆序等题目。涉及切片操作、循环、动态规划、IP地址分类统计以及错误记录管理和密码验证等知识点。对于IP地址判断,强调了Python运算符优先级和掩码合法性判断。在错误记录管理中,提到了使用字典和列表来跟踪错误出现的顺序。密码验证部分提到正则表达式在解决此类问题中的应用。
摘要由CSDN通过智能技术生成

1.数字颠倒
字符串切片操作,c语言中模除取余数输出

n = input().strip()
print(n[::-1])

2.字符串反转
同1,C语言中可以使用for循环逆序输出
3.句子逆序
数组切片操作

s = input().strip().split(' ')
print(' '.join(s[::-1]))  #s为数组所以要用到join方法。
//C语言实现
#include <stdio.h>
#include <string.h>
int main()
{
   
    char a[10000];
    gets(a);
    int j = strlen(a)-1;
    int flag = 1;
    while(j >=0)
    {
   
        int i=j;
        while(a[j] != ' ')
        {
    
            j -- ;
            if (j == -1)
            {
   
                flag = 0;
                break;
            }
        }
        for(int k = j+1;k<=i;k++)
            printf("%c",a[k]);
        if(flag == 1)
            printf(" ");   //注意是""双引号。
        j --;
    }
}

4.字符串的连接最长路径查找
sort函数进行排序

n = int(input())
l = []
for i in range(n):
    l.append(input())
l.sort()
for j in l:
    print(j)

5.int型正整数在内存存储时1的个数
循环将整数与1做与运算,然后将整数右移1位。

n = int(input().strip())
s = bin(n)[2:]
print(s.count('1'))

6.购物单
动态规划问题比较复杂,单独一篇博客列出。
7.坐标移动
从(0,0)开始移动,从输入字符串读取一些坐标,计算最终结果。
比较简单,先做输入字符串合法性检查,然后进行坐标计算。

while True:
    try:
        s = input().strip().split(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值