求素数和杨辉三角

求素数

for循环

##  把所有偶数去掉
import datetime

start = datetime.datetime.now()

n=100000
count=1
for i  in range (3,n,2):    ##
    for j in range(3,int(i ** 0.5)+1,2):  ## 整除的数
        if  i%j==0:
            break
        
    else:
        count += 1
delta = (datetime.datetime.now() - start).total_seconds()
print(count)
print(delta)

列表解法

import datetime

start = datetime.datetime.now()
n=100000
primenumber=[2]
for i in range (3,n,2):
    flag = False
    k = i**0.5
    for j in primenumber:
        if j > k:    
            flag = True
            break
        if i % j == 0:  #  不是质数
            flage = False
            break
    if flag :
        primenumber.append(i)
delta = (datetime.datetime.now() - start).total_seconds()
print(count)
print(delta)

孪生素数解法

import datetime

start = datetime.datetime.now()


l1=[]
l2 = [2,3,5]
num = 5
add = 2
count = 3
n=100000

while num < n: ##3  +2 5  +2 7  +4 11 +2  13  +4  17   19
    if num%5 !=0:
        l1.append(num)
    num = num+ add  
    add = 4  if add == 2  else 2
for i in  l1:
    flag = False
    k= int(i**0.5)
    for j in  l2:
        if j > k:
            flag=True
            break
        if i%j == 0:
            flag= False
            break
    if flag :
        l2.append(i)
        count += 1
delta = (datetime.datetime.now() - start).total_seconds()
print(count)
print(delta)

杨辉三角

杨辉三角 单行覆盖

## 1 先创建一个大列表    [1]*n   
l3 = [1]*(6)
for i in range (6):
    old = 1
    for j in range (i//2):
        val = old+l3[j+1]
        old = l3[j+1]
        l3[j+1]= val
        l3 [i-j-1]=val
    print(l3)

大列表套小列表

 
 triangle=[[1],[1,1]]

for i in range (1,6):
 pre = triangle[i]
 cur=[1]*(i+2)
 
 for j in range (i//2+1):
     val=(pre[j]+pre[j+1])
     cur[j+1] =val
     cur[-j-2] = val
 
 triangle.append(cur)
print(triangle)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值