华为2020校招笔试编程题

刚做完华为的笔试题,简要描述一下三道编程题的解决方法以及python代码实现

第一题大致描述:

给定两个已经升序排序好的的序列A={a1,a2,a3,...an} 和B={b1,b2,b3...bn} ,一个数R,找出满足以下条件的的(ai,bj)序列对

1.ai<=bj

2.bj和ai两者的距离 满足 bj-ai<=R ,要是该条件不满足,就从序列B中找出 和ai 距离最接近R的一个点bj(同时要满足条件1)

输入样例:A={1,3,5},b={2,4,6},R=1

输出样例:(1,2)(3,4)(5,6)

解决思路:遍历所有序列对,找出满足条件的对即可

代码如下:(测试通过)

import sys
s=sys.stdin.readline()
#获取A、B、R的值,用正则表达式匹配会更容易
a=s.find(‘{‘)
b=s.find(‘}‘)
a_str=s[a+1:b].split(‘,‘)
A=[int(x) for x in a_str]
a=s.rfind(‘{‘)
b=s.rfind(‘}‘)
b_str=s[a+1:b].split(‘,‘)
B=[int(x) for x in b_str]
a=s.rfind(‘=‘)
R=int(s[a+1:])
RES=[]
for x in A:
    has_find=False
    for y in B:
        if x<= y and y-x<=R:
            RES.append((x,y))
            has_find=True
        elif x<=y and y-x>R and has_find==False:
            RES.append((x,y))
            break
for x in RES:
    print(‘({},{})‘.format(x[0],x[1]),end=‘‘)

第二题大致描述

对一行给定的字符串进行反转输出,同时去除中间不满足条件的分隔符

输入字符串:I am an 20-years out--standing @ * -stu- dent

去除分割符并反转之后,输出字符串(子字符串以一个空格隔开):dent stu standing out 20-years an am I

分割符描述如下:

1、除了字母、数字和 - 之外,其他的都是分割符,如输入字符串中的@ *等都属于分割符

2、20-years中的‘-‘ 表示的是连接符,即当‘-’两边都有字母、数字时,‘-’就属于连接符,否则属于分割符

3、out--standing中的‘--’表示分割符,应该拆分为两个字字符串out 和 standing

解决思路:用栈去实现,遍历输入字符串的字符:

1、遇到字母和数字就入栈。

2、遇到‘-’的时候就判断是分割符还是连接符,要是是分割符,就弹出所有栈元素,构成一个子字符串,否则就入栈

3、遇到其他分割符,弹出所有栈元素,构成子字符串

找到所有子字符串,就可以做反序输出处理

python代码如下:(测试通过)

import sys
#使用栈去解决问题
#s="I am an 20-years  out--standing @ * -stu- dent"
s=sys.stdin.readline()
word=[]
res=[]
for x in s:
    if ‘0‘<= x <=‘9‘ or ‘a‘<=x <=‘z‘ or ‘A‘<=x<=‘Z‘:
        word.append(x)
    elif x==‘-‘:
        if len(word)==0:
            continue
        else:
            if word[-1]==‘-‘:
                word.pop()
                res.append(‘‘.join(word))
                word = []
            else:
                word.append(x)
    else:
        if len(word)>0:
            if(word[-1]==‘-‘):
                word.pop()
            res.append(‘‘.join(word))
            word=[]
if(len(word)>0):
    if word[-1]==‘-‘:
        word.pop()
    res.append(‘‘.join(word))
for s in res[::-1]:
    print(s,end=‘ ‘)

第三题大致描述如下:

给定多组原本的航班预订信息(航班号,座位号,乘客姓名),以及多组要改签的航班信息(原本航班号,原本座位号,新航班号,新座位号)

输出最后的航班预订信息,要是有重复的内容,以最新改签的为标准

输入的内容如下: 3 表示原本的航班信息数,2表示要改签的航班数

3CZ7132,A1,ZHANGSANCZ7132,A2,ZHAOSICZ7156,A2,WANGWU2CZ7132,A1,CZ7156,A2CZ7156,A2,CZ7156,A3

输出内容如下:CZ7132,A2,ZHAOSICZ7156,A2,ZHANGSACZ7156,A3,WANGW

解决思路,采用python的字典去表示机票位置信息和乘客姓名的对应关系 {piao:name}{name:piao),先找出需要修改航班的乘客姓名,再依次更新该乘客的航班号,航班座位代码如下:
#输入:
#3
#CZ7132,A1,ZHANGSAN
#CZ7132,A2,ZHAOSI
#CZ7156,A2,WANGWU
#2
#CZ7132,A1,CZ7156,A2
#CZ7156,A2,CZ7156,A3
#输出
#CZ7132,A2,ZHAOSI
#CZ7156,A2,ZHANGSAN
#CZ7156,A3,WANGWU

import sys
old_booking_piao_name={}
old_booking_name_piao={}
sum_num=int(input())
for i in range(sum_num):
    msg=input()
    m=msg.rfind(‘,‘)
    piao=msg[0:m]
    name=msg[m+1:]
    old_booking_name_piao[name]=piao
    old_booking_piao_name[piao]=name

chang_booking=[]
num=int(input())
for i in range(num):
    msg = input()
    m = msg.split(‘,‘)
    old = m[0]+‘,‘+m[1]
    new = m[2]+‘,‘+m[3]
    # print(old,new)
    chang_booking.append((old,new))

new_booking_name_piao_copy=old_booking_name_piao.copy()
for x in chang_booking:
    name=old_booking_piao_name[x[0]]
    new_booking_name_piao_copy.pop(name)
    new_booking_name_piao_copy[name]=x[1]

# print(new_booking_name_piao_copy)
for key,val in new_booking_name_piao_copy.items():
    print(val+‘,‘+key)

 

原文地址:https://www.cnblogs.com/mangojun/p/11510959.html

时间: 2024-08-05 18:32:21

华为2020校招笔试编程题的相关文章

美团点评2017秋招笔试编程题

美团点评2017秋招笔试编程题 1, 大富翁游戏,玩家根据骰子的点数决定走的步数,即骰子点数为1时可以走一步,点数为2时可以走两步,点数为n时可以走n步.求玩家走到第n步(n<=骰子最大点数且是方法的唯一入参)时,总共有多少种投骰子的方法. 题解: 写出前面的几个, 1 -> 1;   2 -> 2 ;  3 -> 4;   4 -> 8; 5 -> 16; 6 -> 32; 可以得到是 二的 n-1 次幂. #include <cstdio> int

小米2015笔试编程题

小米2015笔试编程题 1.[编程题] 懂二进制 时间限制:1秒 空间限制:32768K 世界上有10种人,一种懂二进制,一种不懂.那么你知道两个int32整数m和n的二进制表达,有多少个位(bit)不同么? 输入例子1: 1999  2299 输出例子1: 7 分析:第一步求这两个数的异或,得到一个新的数,相同位是0,不同位是1:第二步采用位运算求这个数里边1的个数即为结果 1 class Solution { 2 public: 3 /** 4 * 获得两个整形二进制表达位数不同的数量 5

小米13笔试编程题 1

数组乘积(15分) 输入:一个长度为n的整数数组input 输出:一个长度为n的整数数组result,满足result[i] = input数组中除了input[i]之外所有数的乘积(假设不会溢出).比如输入:input = {2,3,4,5},输出result = {60,40,30,24} 程序时间和空间复杂度越小越好. C/C++: int *cal(int* input , int n); Java: int[] cal(int[] input); 方法1:算出数组所有元素乘积sum,再

小米13笔试编程题 4

朋友圈(25分) 假如已知有n个人和m对好友关系(存于数字r).如果两个人是直接或间接的好友(好友的好友的好友...),则认为他们属于同一个朋友圈,请写程序求出这n个人里一共有多少个朋友圈. 假如:n = 5 , m = 3 , r = {{1 , 2} , {2 , 3} , {4 , 5}},表示有5个人,1和2是好友,2和3是好友,4和5是好友,则1.2.3属于一个朋友圈,4.5属于另一个朋友圈,结果为2个朋友圈. 最后请分析所写代码的时间.空间复杂度.评分会参考代码的正确性和效率. C/

小米13笔试编程题 2

有一个数组(非递减),旋转了不知道多少个位,在该数组中找一个数的下标.写出代码(用C/C++或者java) 并分析时间空间复杂度,考虑效率(很重要). eg:数组 [6,7,1,2,3,4,4] 找3,返回4: 函数原型 C/C++: int find(int * a,int n,int count) count为a数组长度;n为要查找的数 Java: int find(int []a,int n) 方法:二分查找,插值查找,Fibonacci查找 二分查找如下: #include<iostre

2017年腾讯 秋招软件开发笔试编程题回忆版

2017年腾讯秋招软件开发笔试编程题回忆版 (所有题目大致描述如下,并非完整的题目回忆,但意思大致一样) 1.又一个魔法城市,城市里面有n个魔法城堡,序号为0,1,2...n-1:魔法城堡之间都有路径相连:魔法城堡两两之间的到达的距离不同,因此所需时间也可能不会相同.如魔法城堡0到魔法城堡2需要耗时4小时:现,小明想从魔法城堡0到魔法城堡1,他想知道需要花费多少时间:为了快速到达,有一魔法扫把,魔法扫把使用次数有限,使用一次,可以将某一段间的时间减半:求小明从魔法城堡0到魔法城堡1花费的最小时间

笔试编程题必杀技——动态规划

在笔试编程题中,最常见题型莫过于动态规划了,以前一直不太清楚,今天下定决心好好梳理一番. 动态规划是通过组合子问题的解决而解决整个问题的,一个大问题分解成一个小问题,这个小问题再分成小问题,以此类推,直至求出最终结果. 首先看一个把我虐了无数遍的问题:最大子数组的问题. 题目:一个有N个整数元素的一位数组(A[0], A[1],...,A[n-1], A[n]),这个数组当然有很多子数组,那么数组之和的最大值是什么呢? 例如:有数组int A[5] = {-1, 2, 3, -4, 2}:符合条

360笔试编程题

360笔试题目: C++简单实现: 1 #include <stdio.h> 2 #include <iostream> 3 #include <math.h> 4 #include <sstream> 5 #include <cstring> 6 #include <vector> 7 #include <algorithm> 8 9 using namespace std; 10 11 12 const int MAX

2016携程测试实习生笔试编程题

四道大题: 第一道题,是携程网站有一个725*286(具体不记得了)广告区域,能想到的测试类型及方法. 写测试用例——2016年1月1日到2016年3月1日同一订单往返机票立减50 全部功能点. 第二道题,sql语句.(该学sql- -) 第三道题,编程题: 有N个球,M个颜色(M小于等于N),求要想从这N个球里拿出全部(M)个颜色的球,至少需要拿多少个. 思路: 我又是用map实现的,当map的size==M的时候,就说明颜色已经集齐了,计算一个minNum,然后继续扫描,更新minNum 感