Python基础之逻辑题(3)

  1.编写一个函数实现将IP地址转换成一个整数

  2.求结果:---lambda

  3.求a的结果

  4.求下面nums的输出

  5.求下面片段的输出

  6.写出程序的结果:------my_dict

  7.函数结果:---add_end

  8.写函数:data

  9.用两个队列来实现一个栈

  10.写出一下代码的结果并解释:parent

1.编写一个函数实现将IP地址转换成一个整数

如 10.3.9.12 转换规则为:
10 00001010
3 00000011
9 00001001
12 00001100
再将以上二进制拼接起来计算十进制结果: 00001010 00000011 00001001 00001100 = ? --------------------------------------------------------------------------- def func(ip):
a = ip.split('.')
s = ''
l = []
for i in a:
i = bin(int(i))[2:] # bin(10) = 0b1010
i = i.rjust(8, '') # 0000 1010 rjust():返回一个原子符串右对齐,并使用0填充空的新字符串,如果指定的长度小于字符串的长度则返回原字符串。
l.append(i)
s = s.join(l)
return s
ret = func('10.3.9.12 ')
print(int(ret, 2)) str.rjust(width[, fillchar])
-width -- 指定填充指定字符后中字符串的总长度.
-fillchar -- 填充的字符,默认为空格。 2进制 8进制 10进制 16进制
2进制 - bin(x, 8) bin(x, 10) bin(x, 16)
8进制 oct(x, 2) - oct(x, 10) oct(x, 16)
10进制 int(x, 2) int(x, 8) - int(x, 16)
16进制 hex(x, 2) hex(x, 8) hex(int(x, 10))

2.求结果:lambda

def num():
return [lambda x: i * x for i in range(4)] # 返回值是一个列表
print(num())
#[<function num.<locals>.<listcomp>.<lambda> at 0x00000000029726A8>, <function num.<locals>.<listcomp>.<lambda> at 0x0000000002972598>, <function num.<locals>.<listcomp>.<lambda> at 0x0000000002972730>, <function num.<locals>.<listcomp>.<lambda> at 0x00000000029727B8>]
print([m(2) for m in num()])
#[6,6,6,6] def num():
return (lambda x: i * x for i in range(4)) # 返回值是一个生成器
print(num())
#<generator object num.<locals>.<genexpr> at 0x0000000002944B48>
print([m(2) for m in num()])
#[0, 2, 4, 6]

3.求a的结果

a = 1
print(id(a))
def func(a):
a = 2
print(id(a)) #局部变量和全局变量的地址不相同
func(a)
print(a) # 1 对于a变量 在函数中定义了a=2 在函数执行完之后就销毁了 此时打印的a以旧是全局变量的a
a = []
def func(a):
a.append(1)
func(a)
print(a) #[1] 对于列表a 将a传入了函数中为a增加了一个数值 a的地址不变
#可变数据类型与不可变数据类型

4.求下面代码nums的值

num = range(2,20)
for i in num:
num =list(filter(lambda x:x==i or x%i ,num))
print(num) # 答案:[2, 3, 5, 7, 11, 13, 17, 19] num = range(2,20)
for i in num:
num =filter(lambda x:x==i or x%i ,num)
print(num)
print(list(num)) #<filter object at 0x000000000239C4E0>
#[2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19]

5.请给出下面片段的输出

def say_hi(func):
def wrapper(*args,**kwargs):
print('HI') -----------------------------1 先执行
ret = func(*args,**kwargs)
print('BYE')-----------------------------4 后执行
return ret
return wrapper def say_yo(func):
def wrapper(*args,**kwargs):
print('YO')-----------------------------2 调用,所以在4之前
return func(*args,**kwargs)
return wrapper @say_hi
@say_yo
def func():
print('rock&roll')-------------------------------3 装饰器,等2执行完在4之前
func()
结果
HI
YO
rock&roll
BYE

6.请写出程序的输出结果

my_dict ={'a':0,'b':1}
def func(d):
d['a'] = 1 ---------把a的值变成了1
return d
func(my_dict)
my_dict['c'] = 2 -----添加了一个c
print(my_dict)
{'a': 1, 'b': 1, 'c': 2} 字典是可变数据类型

7.函数

def add_end(l=[]):
l.append("end")
return l add_end() # 什么都不输出
add_end() # 什么都不输出

8.写函数

'''
data:{"time":"2016-08-05T13:13:05",
"some_id":"ID1234",
"grp1":{"fld1":1,"fld2":2},
"xxx2":{"fld3":0,
"test":{‘fld5’:0.4}},"fld6":11,"fld7":7,"fld46":8 } fields:由"|"连接的以"fld"开头的字符串,如:fld2|fld3|fld7|fld19  
def select(data,fields):              
return result
'''
data = {
"time":"1989-05-06",
"some_id":123456,
"grp1":{"fld1":1, "fld2":2},
"xxx2":{"fld3":0, "fld4":0.4},
"fld6":11,
"fld7":7,
"fld45":8
} def select(data, field): # "fld2|fld7|fld29"
result = {}
lst = field.split("|") for item in lst:
result[item] = None for item in lst: # "fld2"
if item in data: #
result[item] = data[item] for value in data.values():
if type(value) == dict:
d = select(value, field)
for k, v in d.items():
if v:
result[k] = v
return result
print(select(data, "fld2|fld7|fld29"))

9.用两个队列实现一个栈

思路:
1.任何时候两个队列总有一个是空的。
2.添加元素总是向非空队列中 add 元素。
3.取出元素的时候总是将元素除队尾最后一个元素外,导入另一空队列中,最后一个元素出队。
伪代码:
class StackWithTwoQueues(object):
def __init__(self):
self.q1 = []
self.q2 = []
def push(self,item):
self.q1.append(item)
def pop(self):
if len(self.q1) == 0:
return None
while len(self.q1) != 1:
self.q2.append(self.q1.pop(0))
self.q1,self.q2 = self.q2,self.q1
return self.q2.pop(0)

10请给出正确答案

class Parent(object):
x = 1
class Child1(Parent):
pass
class Child2(Parent):
pass print(Parent.x,Child1.x,Child2.x) #1,1,1 Child1.x = 2
print(Parent.x,Child1.x,Child2.x) #1,2,1 Parent.x = 3
print(Parent.x,Child1.x,Child2.x) #3,2,3 #当子类有值的时候不继承父类,想继承用super()

python基础之逻辑题(3)的更多相关文章

  1. python基础之逻辑题(2)

    python基础之逻辑题(2) 1.若k为整数,下列while循环执行的次数为? 2.请输出正确结果-----numbers? 3.求结果-----math?   4.求结果-----sum? 5.输 ...

  2. python基础之逻辑题(1)

    python基础之逻辑题(1) 1.用一行代码实现数值交换? 2.求结果--fromkeys? 3.1,2,3,4,5能组成多少个互不相同且无重复的三位数? 4.有两个字符串列表a和b,每个字符串是逗 ...

  3. 面试题之第一部分(Python基础篇) 80题

    第一部分(python基础篇)80题 为什么学习Python?==*== # 1. python应用于很多领域,比如后端,前端,爬虫,机器学习(人工智能)等方面,几乎能涵盖各个开发语言的领域,同时它相 ...

  4. python面试题解析(python基础篇80题)

    1.   答:出于编程的喜爱,以及行业本身的前瞻性,创造性,优越性,越是综合的科目越能检验一个人的能力,喜欢这种有挑战的事情. 2.   答:跟随老师学习,以及自己查询资料,结合实战,进行输入输出以及 ...

  5. python(9)- python基础知识刷题

    1.  执行 Python 脚本的两种方式 交互方式:命令行 Windows操作系统下,快捷键cmd,输入“python”启动交互式python解释器. 文件方式:python文件 2.  简述位.字 ...

  6. python基础语法170题

    语言特性 1.谈谈对 Python 和其他语言的区别2.简述解释型和编译型编程语言3.Python 的解释器种类以及相关特点?4.说说你知道的Python3 和 Python2 之间的区别?5.Pyt ...

  7. python基础面试常见题

    1.为什么学习Python? Python是目前市面上,我个人认为是最简洁.最优雅.最有前途.最全能的编程语言,没有之一. 2.通过什么途径学习的Python? 通过自学,包括网上查看一些视频,购买一 ...

  8. python基础易错题

    1.以下代码输入什么: class Person: a = 1 def __init__(self): pass def getAge(self): print(__name__) p = Perso ...

  9. python基础技巧综合训练题2

    1,判断一个字符串中的每一个字母是否都在另一个字符串中,可以利用集合的特性来解,集合的元素如果存在,再次更新(update) 是添加不进集合的,那么集合的长度还是跟原来一样,如果添加进去,集合长度就会 ...

随机推荐

  1. JAVA短信验证码 工具类

    MsgCodeUtil.java package com.hg.util; import com.soyea.enums.ResultEnum; import com.soyea.exception. ...

  2. 二零一七年工作中常用的基本Linux命令记录(Ubuntu)

    Linux命令如下(Ubuntu): 1. apt-get install openssh-server 下载远程工具 2. apt-get install lrzsz 上传下载工具 3. apt-g ...

  3. day37 07-Hibernate二级缓存:查询缓存

    查询缓存是比二级缓存功能更强大的缓存.必须把二级缓存配置好之后才能用查询缓存,否则是用不了的.二级缓存主要是对类的缓存/对象缓存.查询缓存针对对象也是可以的(因为功能比二级缓存更强大),而且还可以针对 ...

  4. Leetcode46. Permutations全排列

    给定一个没有重复数字的序列,返回其所有可能的全排列. 示例: 输入: [1,2,3] 输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1 ...

  5. Python3 中 configparser 模块用法

    configparser 简介 configparser 是 Pyhton 标准库中用来解析配置文件的模块,并且内置方法和字典非常接近.Python2.x 中名为 ConfigParser,3.x 已 ...

  6. Hdu 1025(LIS)

    Constructing Roads In JGShining's Kingdom Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65 ...

  7. Poj 1830 高斯消元

    开关问题 Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 5418 Accepted: 2022 Description 有N个相 ...

  8. android studio离线打包mui应用

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/foolish0421/article/details/54618754首先从官网http://www ...

  9. dijkstra算法为什么不能有负边?

    因为Dijkstra算法在计算最短路径时,不会因为负边的出现而更新已经计算过(收录过)的顶点的路径长度, 这样一来,在存在负边的图中,就可能有某些顶点最终计算出的路径长度不是最短的长度. 假设前两个数 ...

  10. [Vue CLI 3] vue inspect 的源码设计实现

    首先,请记住: 它在新版本的脚手架项目里面非常重要 它有什么用呢? inspect internal webpack config 能快速地在控制台看到对应生成的 webpack 配置对象. 首先它是 ...