东软c语言笔试题2020,华为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)

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

代码如下:(测试通过)

importsys

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 ina_str]

a=s.rfind('{')

b=s.rfind('}')

b_str=s[a+1:b].split(',')

B=[int(x) for x inb_str]

a=s.rfind('=')

R=int(s[a+1:])

RES=[]for x inA:

has_find=Falsefor y inB:if x<= y and y-x<=R:

RES.append((x,y))

has_find=Trueelif x<=y and y-x>R and has_find==False:

RES.append((x,y))break

for x inRES: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代码如下:(测试通过)

importsys#使用栈去解决问题#s="I am an 20-years out--standing @ * -stu- dent"

s=sys.stdin.readline()

word=[]

res=[]for x ins: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表示要改签的航班数

3

CZ7132,A1,ZHANGSAN

CZ7132,A2,ZHAOSI

CZ7156,A2,WANGWU

2

CZ7132,A1,CZ7156,A2

CZ7156,A2,CZ7156,A3

输出内容如下:

CZ7132,A2,ZHAOSI

CZ7156,A2,ZHANGSA

CZ7156,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

importsys

old_booking_piao_name={}

old_booking_name_piao={}

sum_num=int(input())for i inrange(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 inrange(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 inchang_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 innew_booking_name_piao_copy.items():print(val+','+key)

原文出处:https://www.cnblogs.com/mangojun/p/11510959.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值