Python interview preparing
Collection & Recommended:
1. CN - 论坛中看到。 - EN 英文原文真的真的很好好好T_T,看得让人感动T_T
总结个人感兴趣的问题(以下部分参照上面):
1. python 的 函数传值by value 和 函数传址by reference.
In Python everything is an object and all variables hold references to objects.
As result you can not change the value of the reference but you can modify the object if it is mutable.
- See more at: THIS greet blog
理解:
Python,所有都是 对象。变量是 对象的引用。
不能改变 引用本身的值(如果想想C++的引用,reference是不可以再绑定到其他对象,可变的是引用指向的值),但是,如果对象是可变的(mutable),你可以修改对象。
存储模型 | 更新模型 | 访问模型 | |
数值 | 原子 | 不可变immutable | 直接 |
字符串 | 原子 | 不可变immutable | 顺序 |
元组 | 容器 | 不可变immutable | 顺序 |
列表 | 容器 | 可变mutable | 顺序 |
字典 | 容器 | 可变mutable | 映射 |
首先,python中 没有 ’传值‘ 和 ’传址‘ 的概念。
其次,我们希望探索的是, ’传值‘ 和 ’传址‘代表的行为,这有点像‘鸭子判别法’(From - <python cookbook>).
’传值‘行为 代表: 变量a作为参数传入函数func(x)中,func(x)对x的修改不会影响 a本身。
’传址‘行为 代表: 变量a作为参数传入函数func(x)中,func(x)对x的修改 会影响 a本身。
最后,python 类似‘传值’行为: immutable类(标准类型中)
类似‘传址’行为: mutable类(标准类型中)
我的疑问是,如果我自己创建了一个类class,作为变量传入函数,那么class的行为会是什么?这个行为,我可以控制(’传值‘行为 & ’传址‘行为)吗?
2. def test(*argv1, **argv2): pass
http://www.cnblogs.com/kevin922/p/3157752.html - NO.53 - 可变数量的参数。
C语言的“可变数量参数”怎么用呢?
3. List/Dict comprehensions 列表解析 字典解析
3. 1. List Comprehensions - THIS
# try to create a list like this:
>>> matrix = [
... [1, 2, 3, 4],
... [5, 6, 7, 8],
... [9, 10, 11, 12],
... ]
>>> vec1 = [[(x+y) for y in range(0, 4)] for x in range(1, 13, 4)]
另一个有趣的想法
>>> a = [1, 2, 3]
>>> b = [4, 5, 6]
>>> zip(a b)
[(1, 4), (2, 5), (3, 6)]
>>> map(list, zip(a,b))
[[1, 4], [2, 5], [3, 6]]
zip()的实现THIS
def zip(*args):
if not args:
raise TypeError('zip() expects one or more sequence arguments')
ret = []
i = 0
try:
while 1:
item = []
for s in args:
item.append(s[i])
ret.append(tuple(item))
i = i + 1
except IndexError:
return ret
我的问题是 zip(*argv) 这样可以unzip 但是 *argv 是什么?
*argv 是什么 - Answer
zip(*argv) - 析:
>>> zip(*[(1, 4), (2, 5), (3, 6)])
[(1, 2, 3), (4, 5, 6)]
>>> zip((1, 4), (2, 5), (3, 6))
[(1, 2, 3), (4, 5, 6)]
最后!!!
------------------------------- zip(*[iter(s)]*n). 解释 THIS_1, THIS_2
自己的理解是:
在一个list创建迭代器iter,然后因为操作符优先级(operator priority)的缘故,首先创建了 列表[iter, iter, iter],注意,是 列表, 然后对列表unpacking操作作为参数传入了zip(iter, iter, iter)函数.
先暂停,让我们考虑zip(a_list, b_list),假如len(a_list) 等于 len(b_list), zip(a_list, b_list) 的行为是: (a_list[0], b_list[0])组成tuple元组,(a_list[1], b_list[1])组成tuple元组,(a_list[2], b_list[2])组成tuple元组...
再回到zip(iter, iter, iter):
1. 跟C++相同,iter作为迭代器, 假想指针p, ++p之后,p位置会后移, 再次调用p时,要注意p所指向的位置.
2. 同时考虑python对 参数 left-to-right 从左至右 的处理: zip(iter@1, iter@2, iter@3). 注意, iter@1, iter@2, iter@3 就只是一个 iter.
3. zip(iter@1, iter@2, iter@3) 行为是: 遍历 iter@1(iter[0]), iter[0] -> iter[1]; 遍历 iter@2(iter[1]), iter[1] -> iter[2]; 遍历 iter@3(iter[2]), iter[2] -> iter[3]; (iter[0], iter[1], iter[2])组成tuple元组. 依次类推.
# 注意()改变的运算符优先级 >>> a = [1, 2, 3, 4, 5, 6, 7, 8, 9] >>> zip(*[iter(a)]*3)
[(1, 2, 3), (4, 5, 6), (7, 8, 9)] >>> zip(*([iter(a)]*3))
[(1, 2, 3), (4, 5, 6), (7, 8, 9)] >>> x = iter(a)
>>> zip(x, x, x)
[(1, 2, 3), (4, 5, 6), (7, 8, 9)] >>> x_list = [x] * 3
>>> x_list
[<listiterator object at 0x99dafec>, <listiterator object at 0x99dafec>, <listiterator object at 0x99dafec>] >>> a
[1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> x = iter(a)
>>> zip(x, x, x)
[(1, 2, 3), (4, 5, 6), (7, 8, 9)]
>>> zip(*[x, x, x])
[]
>>> zip(x, x, x)
[]
>>> x = iter(a)
>>> zip(*[x, x, x])
[(1, 2, 3), (4, 5, 6), (7, 8, 9)]
>>> x = iter(a)
>>> zip(*[x]*3)
[(1, 2, 3), (4, 5, 6), (7, 8, 9)]
# This is the most interesting one I want to show u
>>> a = [1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> zip(*[iter(a)]*3)
[(1, 2, 3), (4, 5, 6), (7, 8, 9)]
# 注意到zip()的实际行为了吗?在最后一次循环,无法分组的情况下,我的猜测是发生异常,终止了。
>>> zip(*[iter(a)]*4)
[(1, 2, 3, 4), (5, 6, 7, 8)]
# ----啊啊啊 就这样了!!!你们一定能明白了!!我想得头疼了!!!!
3.2. dict comprehension - THIS
>>> [(k, v) for k in range(4) for v in range(4)]
[(0, 0), (0, 1), (0, 2), (0, 3), (1, 0), (1, 1), (1, 2), (1, 3), (2, 0), (2, 1), (2, 2), (2, 3), (3, 0), (3, 1), (3, 2), (3, 3)] >>> # like above, try this:
>>> {k : v for k in range(0, 4) for v in range(0, 4)}
{0: 3, 1: 3, 2: 3, 3: 3} >>> # why above happened??? Try answer. >>> {k: k for k in range(4)}
{0: 0, 1: 1, 2: 2, 3: 3}
>>> {k: 3 for k in range(4)}
{0: 3, 1: 3, 2: 3, 3: 3} # Explain:
dict_test = {}
for k in range(0, 4):
for v in range(0,4):
dict_test[k] = v # finally, dict_test[0] = 3
# In a word, 不允许一个key对应多个value.
And, this is interesting: THIS
And, this is basic part: THIS
4. Python 中 global的使用,产生的问题。
http://www.douban.com/group/topic/40864587/http://www.douban.com/group/topic/40864587/
#! /usr/bin/python
# Filename: global_test.py x = 1
print x def change():
global x
x += 1
print 'change:', x change()
print 'x:', x
5. Python - generator
offical docs - THIS - 感觉看得不够
offical docs - THIS - search 'Generators'
generator
A function which returns an iterator. It looks like a normal function except that it contains yield statements for producing a series a values usable in a for-loop or that can be retrieved one at a time with the next() function. Each yield temporarily suspends processing, remembering the location execution state (including local variables and pending try-statements). When the generator resumes, it picks-up where it left-off (in contrast to functions which start fresh on every invocation).
-----
Generators are a simple and powerful tool for creating iterators. They are written like regular functions but use the yield statement whenever they want to return data. Each time next() is called, the generator resumes where it left-off (it remembers all the data values and which statement was last executed). An example shows that generators can be trivially easy to create.
# a generator that yields items instead of returning a list
def firstn(n):
num = 0
while num < n:
yield num
num += 1
看完上面,我的第一感受是- -!
yield 和 return!如果在for-loop中,不就是 continue 和 break 的区别吗!?!?
再一次深刻知道了自己的俗,是怎么的俗- -!明明是 Such a elegant language~ 我都能解释得这么俗- -!果然是吊丝编程啊- -!
# yield_test.py
def reverse_yield(data):
for index in range(len(data)-1, -1, -1):
yield data[index] for char in reverse_yield('test1'):
print char
# interpretor
kevin922@MyWorld:~/pyShell$ python yield_test.py
1
t
s
e
t
try again:
# yield_test.py
def reverse_yield(data):
for index in range(len(data)-1, -1, -1):
data[index] for char in reverse_yield('test1'):
print char
# interpretor
kevin922@MyWorld:~/pyShell$ python yield_test.py
Traceback (most recent call last):
File "yield_test.py", line 5, in <module>
for char in reverse_yield('test1'):
TypeError: 'NoneType' object is not iterable
again, try:
# yield_test.py
def reverse_yield(data):
for index in range(len(data)-1, -1, -1):
print data[index] reverse_yield('test1') # interpreter
kevin922@MyWorld:~/pyShell$ python yield_test.py
1
t
s
e
t
6. Python - decorator
7. Python - with
8. Python里面如何拷贝一个对象?
python cookbook 4.1
9. python内存管理
10. and-or技巧,说实话,这个技巧很糟糕,我不想使用。
11. python的pass语句作用
空语句。
12、如何在一个function里面设置一个全局的变量?
解决方法是在function的开始插入一个global声明
13. 参考NO.4的解答
a = 1 def change():
a = a + 1 # why is this wrong?
print a pirnt a # -------------------- a = 1 def change():
# without that, why is this right?
print a pirnt a
Python interview preparing的更多相关文章
- python interview questions
referce:python interview questions top 50 refercence:python interview questions top 15 summary Q: wh ...
- [译]Python面试中8个必考问题
1.下面这段代码的输出结果是什么?请解释. def extendList(val, list=[]): list.append(val) return list list1 = extendList( ...
- Python面试常见的问题
So if you are looking forward to a Python Interview, here are some most probable questions to be ask ...
- python进阶资源
本文为不同阶段的Python学习者从不同角度量身定制了49个学习资源. 初学者 Welcome to Python.org https://www.python.org/ 官方Python站点提供了一 ...
- 我的 2019 年 Python 文章榜单
现在是 2020 年的第一天,我相信从昨天开始,各位的信息流里肯定充斥了各式各样的年度盘点/回顾/总结/记录之类的内容.虽然来得稍晚了,但我还是想给诸位送上这一篇文章. 我将在本文中列出自己于 201 ...
- Python Coding Interview
Python Coding Interview Python Advanced Use enumerate() to iterate over both indices and values Debu ...
- Some Interview Questions About Python
一大波超链接即将袭来 Django认证流程 Python实现阶乘 Python文件处理 Python统计日志文件IP出现次数 JSON数据解析 JSON数据解析2 买卖股票的最佳时期 读取一个大文件比 ...
- 《Craking the Coding interview》python实现---01
###题目:给定一个字符串,判断其中是否有重复字母###思路:将重复的字符放入到list中,并进行计数统计###实现:伪代码.函数.类实现###伪代码:string=s #给定的字符串list=[] ...
- 《Craking the Coding interview》python实现---02
###题目:翻转一个字符串###思路:从字符串的最后一位开始,依次取###实现:伪代码.函数.类实现#伪代码: #01string=sNew_s=""for i in range( ...
随机推荐
- struts文件上传拦截器maximumSize设置文件大小不起作用
<interceptor-ref name="fileUpload"> <param name="allowedTypes ...
- C# 中请求数据方式
#region 根据URL获取结果集 /// <summary> /// 根据URL获取结果集 默认为GET,如果数据量大了可以传入POST // ...
- 【转载】C++中结构体的声明和定义
http://blog.csdn.net/whuslei/article/details/5665289 1 //定义一个结构体,类型为struct Student 2 struct Stude ...
- jQuery+css+div--一些细节详解
(一).首先.让我们认识一下最基本普通的alert()弹出框!(改变alert()提示弹出框的样式) 我们在写html或是jsp页面的时候,谁都不希望自己精心设计,且非常美观的页面颜色布局被破坏掉吧! ...
- PE文件结构详解(五)延迟导入表
PE文件结构详解(四)PE导入表讲 了一般的PE导入表,这次我们来看一下另外一种导入表:延迟导入(Delay Import).看名字就知道,这种导入机制导入其他DLL的时机比较“迟”,为什么要迟呢?因 ...
- sql2008安装时提示重启计算机失败解决方法
安装sql 2008的时候,在检测安装环境中有一项是”重新启动计算机”显示的结果是“失败”.上网看了半天,找到了解决方案,虽然我没弄明白具体原因,但问题是解决了,解决方案如下: 一.Windows+R ...
- oracle 字符集
---- 在国内外大中型数据库管理系统中,把ORACLE作为数据库管理平台的用户比较多.ORACLE 不论是数据库管理能力还是安全性都是无可非议的,但是,它在汉字信息的显示方面着实给中国用户带来不少麻 ...
- DevOps 和技术债务偿还自动化
当企业想要迁移到一个 DevOps 模型时,经常需要偿还高等级的技术债务 说得更明确一点,机构往往陷入「技术债务的恶性循环」中,以至于任何迅速.敏捷的迁移方式都无法使用.这是技术债务中的希腊债务危机水 ...
- How to use Mac Terminal
Mac OS X 启用超级用户的方法Root user,又名超级用户,是一个权力最高的Unix 账户,Root 的账户能在整个系统里任何部份进行任何“操作”,包括:拷贝档案.移动/移除档案.执行程序等 ...
- POJ 3280 Cheapest Palindrome(DP)
题目链接 题意 :给你一个字符串,让你删除或添加某些字母让这个字符串变成回文串,删除或添加某个字母要付出相应的代价,问你变成回文所需要的最小的代价是多少. 思路 :DP[i][j]代表的是 i 到 j ...