typedef long long ll; void exgcd(ll a,ll b,ll &gcd,ll &x,ll &y)//ax+by=gcd { if(!b){gcd=a;x=1;y=0;return;} exgcd(b,a%b,gcd,y,x); y-=x*(a/b); }
在学 py 的时候觉得最好的方法还是去刷题。。。 就是这样的一段 C++实现的扩展欧几里德, py 单变量不支持传递引用的特性却让改写变得有点麻烦,我能想到的是直接 global (太黄暴)或者传 list (担心会降低效率(虽然在 python 上担心效率似乎很滑稽?))
因为是初学 py ,所以想问问老司机们有没有更优雅的惯用做法?
1
sfqtsh 2016-07-23 22:57:04 +08:00 via Android
gcd 什么鬼?
|
3
htfy96 2016-07-24 00:12:21 +08:00 via Android
搞个类包一下?
|
4
northisland 2016-07-24 00:35:32 +08:00 via Android
就仨参数?静态指针数组?
参数复杂的,用 protobuf 生成类,或者你自己写个类,用来传参。我的想法。 另外不明白你为啥谈谈 c++,又谈谈 python |
5
northisland 2016-07-24 01:04:26 +08:00 via Android
我印象中 Python 里,
当作参数传递时, 传递原参数的引用的有:可变容器,类; 传递原参数的副本的有:不可变容器,基本数据类型。 想传引用,只能按套路出牌。 个人感觉 python 不必过分在意效率,毕竟是比 c++慢 10 到 100 倍的高级语言。 |
6
FrankHB 2016-07-24 02:26:34 +08:00 2
……你这 C 艹读着也疼得紧啊。
一行 template<typename T>搞定的东西,非得 typedef 啥 ll 邪教…… |
7
feuvan 2016-07-24 11:09:18 +08:00
ll 邪教
|
8
tempdban 2016-07-26 08:19:25 +08:00 via Android
兄弟你这高数都五个参数了 ,打包到 List 里石油多难…
|