感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:
① 2000多本Python电子书(主流和经典的书籍应该都有了)
② Python标准库资料(最全中文版)
③ 项目源码(四五十个有趣且经典的练手项目及源码)
④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)
⑤ Python学习路线图(告别不入流的学习)
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
print(i)
=========================================================================
众所周知,Python数值型的位数与电脑内存有关。可以很轻松实现n的阶乘
但是对于C、C++而言整型的位数是有一定长度的。超过一定长度就会溢出
输入不超过1000的正整数n,输出n!=1_2_3_4_…*n的精确结果。
样例输入:30
样例输出:265252859812191058636308480000000
很长很长的计算结果对于Python语言而言不会有太大影响,因为Pyhton会根据电脑内存的大小决定整型的大小。而对于C\C++这样的语言而言,数值型都有一定的长度。超过一定长度发生溢出之后将会影响最终的结果。这一个题目我们需要使用数组进行计算结果的存储,然后自己模拟乘法运算。最终得到计算结果。
老规矩先上运行结果:
上代码:
在这里使用了两种方式,一种是直接计算,另一种就是使用C语言风格进行模拟乘法。
由于Python内置模块较为强大直接计算超级方便还可以计算出很长的数,只需要很少的时间
(如下图)但是我们今天为自己找事情做,就使用Pyhton语言模拟一下C语言的写法。
即便计算10000的阶乘花费的时间依旧不到秒
import time
def timmer(func):
def weapper(*s):
start=time.time()
func(*s)
end=time.time()
print(“用时:”,end-start)
return weapper
@timmer
def f1(n):
直接计算
ans=1
用于标记现在是所在的位数
if n0 or n1:
print(1)
exit()
else:
for i in range(2,n+1):
ans=ans*i
print(ans)
@timmer
def f2(n):
C语言方法精确计算
ans=[0]*1000
ans[0]=1
for i in range(2,n+1):
j=0
c=0
while j<1000:
temp=ans[j]*i+c
ans[j]=temp%10
c=temp//10
j+=1
i=len(ans)-1
flag=True
while i>=0:
if flag and ans[i]==0:
pass
else:
print(ans[i],end=“”)
flag=False
i-=1
print()
if name==“main”:
n=int(input())
f1(n)
f2(n)
========================================================================
素数又称质数,他是只能被1与他本身整除的整数,并且大于1现给出一个数,比他小的孪生素数
孪生素数的意思就是连续挨着的两个素数,并且他的的差为2(即 n与n-2)
现在给出一个正整数,请计算出比他小但是距离他最近的两个孪生素数。
样例输入:1000
样例输出:881 883
判断是不是孪生素数,首先要确定是不是素数。是的话再判断与其相差2的数是不是素数。
如果两个都是的话直接进行输出,否则继续判断。
老规矩先上运行结果:
上代码:
def is_ok(num):
if num==1:
return False
for i in range(2,int(math.sqrt(num))+1):
if num%i==0:
return False
return True
n=int(input())
while n:
if is_ok(n) and is_ok(n-2):
print(n-2,n)
break
n-=1
==========================================================================
假设你有各位数字互不相同的四位数。将该数中的数字从大到小排序后得到a
从小到大排序后得到b,然后使用a-b得到的结果取代原来的数。并继续相同的操作。
任务:输入一个数n输出操作序列。直到出现循环,比如排序前的6174生成的结果也是6174
样例输入:1234
样例输出:1234—>3087—>8352—>6174—>6174
涉及到对数值中的数字进行排序
排序完后使用大的减去小的,然后对比生成的结果与原来的数。
老规矩先上运行结果:
上代码:
自定义排序函数,如果r=True就是降序
def msort(n,r=True):
ans=0
temp=[]
//将数值转换为列表
while n:
temp.append(n%10)
n//=10
#在刚刚进行排序的时候高位与低位进行了颠倒,再颠倒回来
temp=temp[::-1]
如果你也是看准了Python,想自学Python,在这里为大家准备了丰厚的免费学习大礼包,带大家一起学习,给大家剖析Python兼职、就业行情前景的这些事儿。
一、Python所有方向的学习路线
Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
二、学习软件
工欲善其必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。
三、全套PDF电子书
书籍的好处就在于权威和体系健全,刚开始学习的时候你可以只看视频或者听某个人讲课,但等你学完之后,你觉得你掌握了,这时候建议还是得去看一下书籍,看权威技术书籍也是每个程序员必经之路。
四、入门学习视频
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。
四、实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
五、面试资料
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
成为一个Python程序员专家或许需要花费数年时间,但是打下坚实的基础只要几周就可以,如果你按照我提供的学习路线以及资料有意识地去实践,你就有很大可能成功!
最后祝你好运!!!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!