python-鸡尾酒疗法/图像相似度/第n小的质数

一:鸡尾酒疗法
题目描述

鸡尾酒疗法,原指“高效抗逆转录病毒治疗”(HAART),由美籍华裔科学家何大一于 1996 年提出,是通过三种或三种以上的抗病毒药物联合使用来治疗艾滋病。该疗法的应用可以减少单一用药产生的抗药性,最大限度地抑制病毒的复制,使被破坏的机体免疫功能部分甚至全部恢复,从而延缓病程进展,延长患者生命,提高生活质量。
人们在鸡尾酒疗法的基础上又提出了很多种改进的疗法。为了验证这些治疗方法是否在疗效上比鸡尾酒疗法更好,可用通过临床对照实验的方式进行。
假设鸡尾酒疗法的有效率为 x,新疗法的有效率为 y,如果 y−x 大于 5%,则效果更好,如果 x−y 大于 5%,则效果更差,否则称为效果差不多。
下面给出 n 组临床对照实验,其中第一组采用鸡尾酒疗法,其他 n−1 组为各种不同的改进疗法。请写程序判定各种改进疗法效果如何。
输入
第一行为整数 n(1<n≤20);
其余 n 行每行两个整数,第一个整数是临床实验的总病例数(小于等于10000),第二个疗效有效的病例数。
这 n 行数据中,第一行为鸡尾酒疗法的数据,其余各行为各种改进疗法的数据。
输出
有 n−1 行输出,分别表示对应改进疗法的效果:
如果效果更好,输出 better;如果效果更差,输出 worse;否则输出 same。
样例输入1
5
125 99
112 89
145 99
99 97
123 98

样例输出1
same
worse
better
same

来源/分类(难度系数:一星)
每日一题 循环结构


完整代码展示:
a=int(input())
b=[]
for i in range(a):
      c=list(map(int,input().split()))
      d=(c[1]/c[0])*100
      b.append(d)
for j in range(1,len(b)):
      if b[j]-b[0]>5:
           print("better")
      elif b[0]-b[j]>5:
           print("worse")
      else:
             print("same")

a=int(input())
b=[]
for i in range(a):
    c=list(map(int,input().split()))
    d=(c[1]/c[0])*100
    b.append(d)
for j in range(1,len(b)):
    if b[j]-b[0]>5:
        print("better")
    elif b[0]-b[j]>5:
        print("worse")
    else:
        print("same")


代码解释:
“a=int(input()) ”,导入用输入的临床病组数a。
“b=[]
 for i in range(a):
       c=list(map(int,input().split()))
       d=(c[1]/c[0])*100
       b.append(d)                             ”,建立一个空列表b,接着循环a次:让用户输入临床病例的总人数和疗效有效的病例数。并将其储存在列表c中,再将c[i]/c[0]*100添加进b中。
“for j in range(1,len(b)):
       if b[j]-b[0]>5:
            print("better")
       elif b[0]-b[j]>5:
            print("worse")
       else:
              print("same")  ”,遍历b中元素:判断该元素是否大于5,如果大于5:打印“better”,如果小于5:打印“worse”,否则打印“same”。


运行效果展示:

6b9fba21aa58442dab04c81d1acd9ccf.jpg

11411df15c724d47ba9aeaae7395068d.jpg 

 

 

 

 

二:图像相似度
题目描述

给出两幅相同大小的黑白图像(用 0−1 矩阵)表示,求它们的相似度。
说明:若两幅图像在相同位置上的像素点颜色相同,则称它们在该位置具有相同的像素点。两幅图像的相似度定义为相同像素点数占总像素点数的百分比。
输入
第一行包含两个整数 m 和 n,表示图像的行数和列数,中间用单个空格隔开1≤m≤100,1≤n≤100。
之后 m 行,每行 n 个整数 0 或 1,表示第一幅黑白图像上各像素点的颜色。相邻两个数之间用单个空格隔开。之后 m 行,每行 n 个整数 0 或 1,表示第二幅黑白图像上各像素点的颜色。相邻两个数之间用单个空格隔开。
输出
一个实数,表示相似度(以百分比的形式给出),精确到小数点后两位。
样例输入1
3 3
1 0 1
0 0 1
1 1 0
1 1 0
0 0 1
0 0 1

样例输出1
44.44

来源/分类(难度系数:一星)
每日一题 数组


完整代码展示:
a,b=map(int,input().split())
c=[]
d=[]
for i in range(a):
      e=list(map(int,input().split()))
      c.append(e)
for i in range(a):
      f=list(map(int,input().split()))
      d.append(f)
g=0
sum=0
while g<len(c):
       for j in range(0,b):
             if c[g][j]==d[g][j]:
                  sum+=1
       g+=1
print("{:.2f}".format((sum/(a*b))*100))

a,b=map(int,input().split())
c=[]
d=[]
for i in range(a):
    e=list(map(int,input().split()))
    c.append(e)
for i in range(a):
    f=list(map(int,input().split()))
    d.append(f)
g=0
sum=0
while g<len(c):
    for j in range(0,b):
        if c[g][j]==d[g][j]:
            sum+=1
    g+=1
print("{:.2f}".format((sum/(a*b))*100))


代码解释:
“a,b=map(int,input().split()) ”,导入用户输入的代表图像的行数a和列数b。
“c=[]
 d=[]
 for i in range(a):
       e=list(map(int,input().split()))
       c.append(e)
 for i in range(a):
       f=list(map(int,input().split()))
       d.append(f)                             ”,建立一个空列表c,接着循环a次:导入用户输入的代表黑百图像的各像素点颜色的数据。并将其储存在列表e中,再将e添加进c中。下同。
“g=0
 sum=0
 while g<len(c):
        for j in range(0,b):
              if c[g][j]==d[g][j]:
                   sum+=1
        g+=1                       ”,令sum为0,g为循环密码子,初始值为0,当g<len(c)时:遍历c[b]中元素,判断c[g][i]是否与d[g][i]相同,如果相同,sum+1。每循环一次,g+1,当g==len(c)时,跳出整个while循环。
print("{:.2f}".format((sum/(a*b))*100)) ”,打印sum/a*b的值并保留2位有效数字。


运行效果展示:

9ad8dd38e6984169a0e8bfcc0b84328c.jpg

2dbea17948554b05a8692d258d576210.jpg 

 

 

 

 

三:第n小的质数
题目描述

输入一个正整数 n,求正整数范围中第 n 小的质数。
输入
一个不超过 30000 的正整数 n。
输出
第 n 小的质数。
样例输入1
10

样例输出1
29

来源/分类(难度系数:一星)                            每日一题 循环结构


完整代码展示:
import math
a=int(input())
b=[]
c=len(b)
i=2
while c<a:
       j=2
       k=int(math.sqrt(i))
       while j<=k:
              if i%j==0:
                  break
              j=j+1
       if j>k:
           b.append(i)
           c+=1
       i+=1
print(b[-1])

import math
a=int(input())
b=[]
c=len(b)
i=2
while c<a:
    j=2
    k=int(math.sqrt(i))
    while j<=k:
        if i%j==0:
            break
        j=j+1
    if j>k:
        b.append(i)
        c+=1
    i+=1
print(b[-1])


代码解释:
“import math ”,导入math库。
“a=int(input()) ”,导入用户输入的正整数n。
“b=[]
 c=len(b)
 i=2
 while c<a:
        j=2
        k=int(math.sqrt(i))
        while j<=k:
               if i%j==0:
                   break
               j=j+1
        if j>k:
            b.append(i)
            c+=1
        i+=1                       ”,建立一个空列表b,令i为循环密码子,初始值为2,c为列表中元素数量,当c<a时:利用质数的定义判断i是否为质数,如果是:则将i添加进b中,c+1。每循环一次,i+1,直至c==a,跳出整个while循环。
“print(b[-1]) ”,打印b中的最后一个元素。


运行效果展示:

6b918864c1b5469d8c0efa5e0adbd990.jpg

9c19793f7280474a986695de35aa4675.jpg 

                (声明:以上内容均为原创)

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

闪云-微星

感谢大家的支持与鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值