python基础小白题

题目1:有1、2、3、4四个数,能组成多少个互不相同且无重复的三位数?都是多少?

list_num=[1,2,3,4]

all_num=[]

for i in list_num:

    for j in list_num:

        for k in list_num :

            if (i!=j) and (i!=k) and (j!=k):

                num=i*100+j*10+k

                all_num.append(num)

print(all_num) 

print('A total of %d numbers.' %len(all_num))

题目2:企业发放的奖金根据利润提成。

    低于或等于10万元时,奖金可提成10%;

    高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;

    20万到40万之间时,高于20万元的部分可提成5%;

    40万到60万之间时,高于40万元的部分,可提成3%;

    60万到100万之间时,高于60万的部分,可提成1.5%;

    超过100万元的部分按1%提成;

    从键盘输入当月利润,求应发奖金总数。

while True:

    num=input('请输入利润:').strip()

    if num.isdigit():

        pass

    else :

        print('输入的利润必须为数字') 

        continue

    num=int(num)    #转换为整数类型

    if num > 1000000 :

        profit = (num-1000000)*0.01 + 400000*0.015 + 200000 *0.03 + 200000*0.05 + 100000*0.075 + 100000*0.1

        break

    elif num > 600000 :

        profit = (num-400000)*0.015 + 200000 *0.03 + 200000*0.05 + 100000*0.075 + 100000*0.1 

        break

    elif num > 400000 :

        profit = (num-200000) *0.03 + 200000*0.05 + 100000*0.075 + 100000*0.1

        break

    elif num > 200000 :

        profit = (num-200000)*0.05 + 100000*0.075 + 100000*0.1

        break

    elif num > 100000 :

        profit = (num-100000)*0.075 + 100000*0.1

        break

    else :

        profit = num*0.1

        break

print('应发奖金总数为:%d' %profit)

题目3:一个整数,它加上100后是一个完全平方数。再加上168又是一个完全平方数,问该数是多少。

 

import math

int_num=0

while True:

    num1=math.sqrt(int_num+100)

    num2=math.sqrt(int_num+168)

    if num1==int(num1) and num2 == int(num2):

        break

    int_num += 1

print('该整数为 %d' %int_num)

题目4:输入某年某月某日,判断这一天是这一年的第几天。(格式 如:19870604)

 

from builtins import len

leap_year={'01':31,'02':29,'03':31,'04':30,'05':31,'06':30,

           '07':31,'08':31,'09':30,'10':31,'11':30,'12':31}    #闰年每月最大天数

comm_year={'01':31,'02':28,'03':31,'04':30,'05':31,'06':30,

           '07':31,'08':31,'09':30,'10':31,'11':30,'12':31}     #平年每月最大天数

while True:

    num = input('请输入日期,格式如19540105:')

    if num.isdigit() and len(num)==8 :                      

        pass

    else :

        print('格式错误,请重新输入')

        continue

    year_num=int(num[:4]) 

    month_num=num[4:6]

    day_num=int(num[6:])

    if (int(month_num)>12) or (int(month_num)<=0):     #月份错误时,重新输入,'01'字符串转换为整数时,会舍弃0,无法遍历字典

            print('月份输入错误,请重新输入。')

            continue

    days=0                                                       #定义天数

                                                         

    if ((year_num%100==0) and (year_num%400 == 0)) or ((year_num%100 !=0) and (year_num%4 == 0)):   #如果是闰年

        if (day_num > leap_year[month_num]) or (day_num <= 0): #日期错误时重新输入

            print('此月份中没有这一天,请重新输入。')

            continue

        for i in leap_year.keys():                               #遍历月份

            if int(i) < int(month_num):

                days = days + leap_year[i]

            elif int(i)==int(month_num):

                days = days + day_num

    else:                                                       #如果是平年

        if (day_num > comm_year[month_num]) or (day_num <= 0):  #日期错误时重新输入

            print('此月份中没有这一天,请重新输入。')

            continue

        for i in comm_year.keys():                               #遍历月份

            if int(i) < int(month_num):

                days = days + comm_year[i]

            elif int(i)==int(month_num):

                days = days + day_num

    print('这一天是今年的第 %d 天' %days)

    break

题目5:输入三个整数x,y,z,请把这三个数从小到大输出。

 

def isint(num):

    while True:

        a=input('请输入整数 %s:' %num).strip()

        if a.isdigit() :

            break

        else:

            print(' %s 不是整数,请重新输入' %a)

    return a

dic={}

dic['x']=isint('x')

dic['y']=isint('y')

dic['z']=isint('z')

dic=list(dic.values())

dic.sort()

print(dic)

题目6:用*输出字母c的图案。

 

list_c=['  **** ',' *    *','*','*','*',' *    *','  **** ']

for i in list_c:

    print(i)

     

输出结果:

  **** 

 *    *

*

*

*

 *    *

  ****

题目7:输出9*9口诀表。

 

for i in range(1,10):

    j=1

    while j<=i:

        print('%d*%d=%-2d ' % (j,i,(i*j)),end='')

        j +=1

    print(end='\n')

输出结果:

1*1=1  

1*2=2  2*2=4  

1*3=3  2*3=6  3*3=9  

1*4=4  2*4=8  3*4=12 4*4=16 

1*5=5  2*5=10 3*5=15 4*5=20 5*5=25 

1*6=6  2*6=12 3*6=18 4*6=24 5*6=30 6*6=36 

1*7=7  2*7=14 3*7=21 4*7=28 5*7=35 6*7=42 7*7=49 

1*8=8  2*8=16 3*8=24 4*8=32 5*8=40 6*8=48 7*8=56 8*8=64 

1*9=9  2*9=18 3*9=27 4*9=36 5*9=45 6*9=54 7*9=63 8*9=72 9*9=81

题目8:斐波那契数列。即:0,1,1,2,3,5,8,13。

  数学定义:F0=0,F1=1,Fn=f(n-1)+F(n-2)

 

def fibonacci_sequence(n):

    if n==0:

        return 0

    elif n==1:

        return 1

    else:

        return fibonacci_sequence(n-1)+fibonacci_sequence(n-2)

num=int(input('请输入一个整数:'))

for i in range(num):

    val=fibonacci_sequence(i)

    print('n=%d,Fn=%d ' %(i,val))

输出结果:

请输入一个整数:10

n=0,Fn=0 

n=1,Fn=1 

n=2,Fn=1 

n=3,Fn=2 

n=4,Fn=3 

n=5,Fn=5 

n=6,Fn=8 

n=7,Fn=13 

n=8,Fn=21 

n=9,Fn=34

题目9:输出国际象棋棋盘。

 

a=' '

for i in range(8):

    for j in range(8):

        if i%2==0:

            if j%2==0 :

                print('\033[7;37m%s\033[0m' %a,end='')

            else:

                print('\033[7;30m%s\033[0m' %a,end='')

        else:

            if j%2!=0 :

                print('\033[7;37m%s\033[0m' %a,end='')

            else:

                print('\033[7;30m%s\033[0m' %a,end='')

    print(end='\n')

输出结果:

wKioL1i8DYagYYA8AAALeRULEsM081.png-wh_50

题目10:古典问题,有一对兔子,从出生后第三个月起每个月都出生一对兔子,小兔子涨到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少。

 

def rabbit_num(n):

    if n==1:

        return 1

    elif n==2:

        return 1

    else:

        return rabbit_num(n-1)+rabbit_num(n-2)

num=int(input('请输入一个整数:'))

for i in range(1,num+1):

    val=rabbit_num(i)

    print('n=%d,Fn=%d ' %(i,val))

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/445643.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python基础小白题2

题目11&#xff1a;判断101-200之间有多少个素数&#xff0c;并输出所有素数。 num[] for i in range(100,201): ji//2 for k in range(2,j): if i%k0: break else: num.append(i) print(一共有%d个素数\n这些素数是&#xff1a; %len(num),num ) 输出结果&am…

python基础小白题3

题目021&#xff1a;猴子吃桃问题 猴子第一天摘下若干个桃子&#xff0c;当即吃了一半&#xff0c;还不瘾&#xff0c;又多吃了一个 第二天早上又将剩下的桃子吃掉一半&#xff0c;又多吃了一个。 以后每天早上都吃了前一天剩下的一半零一个。 到第10天早上想再吃时&#x…

python基础小白题4

题目031&#xff1a;请输入星期几的第一个字母来判断一下是星期几&#xff0c;如果第一个字母一样&#xff0c;则继续判断第二个字母。 def tm031(): 【个人备注】&#xff1a;按照题意要求实现了就行 week [monday,tuesday,wednesday,thursday,friday,saturday,sunday] inp…

python基础小白题5

题目045&#xff1a;统计 1 到 100 之和。 def tm045(): 【个人备注】&#xff1a;简单&#xff0c;但官网有人写的更简单 s 0 for i in range(1,101): si print(s) # 更简洁的方法 print(sum(range(1,101))) 题目046&#xff1a;求输入数字的平方&#xff0c;如果平方运算…

快排-荷兰国旗

在使用partition-exchange排序算法时&#xff0c;如快速排序算法&#xff0c;我们会遇到一些问题&#xff0c;比如重复元素太多&#xff0c;降低了效率&#xff0c;在每次递归中&#xff0c;左边部分是空的(没有元素比关键元素小)&#xff0c;而右边部分只能一个一个递减移动。…

快排-前m大元素

描述 给定一个数组包含n个元素&#xff0c;统计前m大的数并且把这m个数从大到小输 出。 输入 第一行包含一个整数n&#xff0c;表示数组的大小。n < 100000。 第二行包含n个整数&#xff0c;表示数组的元素&#xff0c;整数之间以一个空格分开 。每个整数的绝对值不超过…

归并-求逆序数

考虑1,2,…,n (n < 100000)的排列i1&#xff0c;i2&#xff0c;…&#xff0c;in&#xff0c;如果其中存在j,k&#xff0c;满足 j < k 且 ij > ik&#xff0c; 那么就称(ij,ik)是这个排列的一个逆序。 一个排列含有逆序的个数称为这个排列的逆序数。例如排列 26345…

动态规划概述

注&#xff1a;第一次看不需要全理解&#xff0c;以后动态规划做多了&#xff0c;再回来看看&#xff0c;会有更深的理解 先符上其它文章&#xff0c;看完这篇就可以开始看这些咯。 萌新&#xff1a; …

动态规划-背包是否装满

很简单但是需要特别注意的&#xff0c;一定不要错。 背包&#xff1a; 有n 种不同的物品&#xff0c;每个物品有两个属性&#xff0c;v体积&#xff0c;c价值&#xff0c;现在给一个体积为 m 的背包&#xff0c;问最多可带走多少价值的物品。 状态转移方程 dp[i][j]max…

dp打开思路3:HDU1069 POJ3616 POJ1088

HDU 1069 题目链接&#xff1a;http://acm.hdu.edu.cn/showproblem.php?pid1069 题意&#xff1a;把给定的长方体&#xff08;不限&#xff09;叠加在一起&#xff0c;叠加的条件是&#xff0c;上面一个长方体的长和宽都比下面长方体的长 和宽短&#xff1b;求这些长方体能…

输入输出外挂

板子不解释 //适用于正负整数 template <class T> inline bool scan_d(T &ret) {char c; int sgn;if(cgetchar(),cEOF) return 0; //EOFwhile(c!−&&(c<0||c>9)) cgetchar();sgn(c−)?−1:1;ret(c−)?0:(c−0);while(cgetchar(),c>0&&c&…

dp打开思路4:POJ1189 UVA12511 HDU2845 HBCPC K

POJ1189 http://poj.org/problem?id1189 怎么说呢&#xff0c;不算难&#xff0c;但是容易出问题 我一开始的思路是&#xff0c;第一个钉子只有一种情况&#xff0c;然后下面每个钉子&#xff1a;左边有钉子就加左边的情况数&#xff0c;右边有钉子就加右边的情况数&#x…

第五次课 课上代码

第五次 双重循环——排序&#xff08;复习&#xff09; While循环 Break continue 字符串&#xff08;len&#xff0c;取值改值&#xff0c;格式化&#xff09; 列表生成式 >>> for i in range(4): for j in range(4): print(i,j) 0 0 0 1 0 2 0 3 1…

第六次课 课上代码

oj的使用 Python Split 函数&#xff08;优点&#xff1a;抽象、简洁。 举例&#xff1a;str\int\float\abs 具体实现&#xff09; ninput().split(" ") 3 4 >>> print(int(n[0])int(n[1])) 7 >>> print(12345) 15 l[1,2,3,4,5] >>&g…

橙白oj18训练作业1-题解、代码

学习资料和oj如何使用加软件官方qq群739979255 oj网址&#xff1a;http://oj.acm-icpc.top/ a题&#xff1a;原题为输入两个数&#xff0c;一行&#xff0c;用空格隔开&#xff0c;因为python操作对萌新来说略难&#xff0c;改为一行一个数&#xff0c;算出ab。 思路&#x…

橙白oj18训练作业2-题解、代码

http://oj.acm-icpc.top/ a题&#xff1a;三个数字排序 可以利用sort函数排序&#xff0c;或者自己想清楚逻辑自己写&#xff0c;我给出一个正确逻辑 &#xff08;拓展冒泡和其他排序参考https://blog.csdn.net/hebtu666/article/details/81434236&#xff09; a,b,cinput(…

时间空间复杂度概述

找个时间写一写时间复杂度和一些问题分类&#xff0c;也普及一下这方面知识。 如何衡量一个算法好坏 很显然&#xff0c;最重要的两个指标&#xff1a;需要多久可以解决问题、解决问题耗费了多少资源 那我们首先说第一个问题&#xff0c;要多长时间来解决某个问题。那我们可…

二叉树遍历算法总结

文章目录前提要素深度优先搜索DFS经典遍历算法前序遍历递归版迭代版中序遍历递归版迭代版后序遍历递归版迭代版Morris遍历算法中序遍历前序遍历后序遍历广度优先搜索BFS按层遍历参考资料前提要素 本文代码用Java实现。 //二叉树节点结构 public static class TreeNode {publi…

时间复杂度 P/NP/NPC

你会经常看到网上出现“这怎么做&#xff0c;这不是NP问题吗”、“这个只有搜了&#xff0c;这已经被证明是NP问题了”之类的话。你要知道&#xff0c;大多数人此时所说的NP问题其实都是指的NPC问题。他们没有搞清楚NP问题和NPC问题的概念。NP问题并不是那种“只有搜才行”的问…