本部分来源于菜鸟教程100道中
菜鸟教程链接一百题地址:Python 100例 | 菜鸟教程
第一题
题目:有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满足条件的排列。
#coding = utf-8
count=0
for i in range(1,5):
for j in range(1,5):
for k in range(1,5):
if (i!=j) and (j!=k) and (k!=i):
print(f"{i}{j}{k}")
count=count+1
print(f"一共有{count}种方案")
第二题
题目:企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?
程序分析:请利用数轴来分界,定位。
#coding = utf-8
def SalaryCount(money):
GetMoney=0
arr = [1000000, 600000, 400000, 200000, 100000, 0]
rat = [0.01, 0.015, 0.03, 0.05, 0.075, 0.1]
for i in range(0,6):
if money>arr[i]:
GetMoney+=(money-arr[i])*rat[i]
money=arr[i]
print(f"最终获得提成{GetMoney}")
money=1200000
SalaryCount(money)
第三题
题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
#coding = utf-8
import math
def check(n): # n:被判断的数
a = int(math.sqrt(n))
return a * a == n
for i in range(-100,10000):#从-100-10000中去寻找这个数
num1=i+100
num2=i+100+168
if(check(num1) and check(num2)):
print(f"{i}是符合要求的数")
第四题
题目:输入某年某月某日,判断这一天是这一年的第几天?
程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊情况,闰年且输入月份大于2时需考虑多加一天:
#coding = utf-8
'''输入某年某月某日,判断这一天是这一年的第几天?'''
run_dict = {1: 31, 2: 29, 3: 31, 4: 30, 5: 31, 6: 30, 7: 31, 8: 31, 9: 30, 10: 31, 11: 30, 12: 31}
ping_dict = {1: 31, 2: 28, 3: 31, 4: 30, 5: 31, 6: 30, 7: 31, 8: 31, 9: 30, 10: 31, 11: 30, 12: 31}
year = int(input("请输入年份:"))
month = int(input("请输入月份:"))
date = int(input("请输入日期:"))
sum = 0
if 0 < month <= 12 and 0 < date <= 31:
if (year % 400 == 0) or ((year % 400 == 0)) and (year % 100 != 0):
for i in range(1, month):
sum = sum + run_dict[i]
print("这一天是{}的第{}天".format(year, sum + date))
else:
for i in range(1, month):
sum = sum + ping_dict[i]
print("这一天是{}的第{}天".format(year, sum + date))
else:
print("Data Error")
第五题
题目:输入三个整数x,y,z,请把这三个数由小到大输出。
程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小。
#coding = utf-8
alist=list(input().split(" "))
alist.sort()
for i in range(len(alist)):
print(alist[i],end=" ")
第六题
题目:斐波那契数列。
程序分析:斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、……。
在数学上,费波那契数列是以递归的方法来定义:
# -*- coding: UTF-8 -*-
# 使用递归
def fib(n):
if n == 1 or n == 2:
return 1
return fib(n - 1) + fib(n - 2)
# 输出了第10个斐波那契数列
print(fib(10))
第七题
题目:将一个列表的数据复制到另一个列表中。
#coding = utf-8
alist=[1,2,3,4,5,6,7,8,9,10]
blist=[]
blist.extend(alist)
print(blist)
第八题
题目:输出 9*9 乘法口诀表。
程序分析:分行与列考虑,共9行9列,i控制行,j控制列。
#coding = utf-8
# 左上角九九乘法表
for row1 in range(1,10): #打印行
for col1 in range(row1,10): #打印列
print("{0}*{1}={2:2d}".format(row1,col1,row1*col1),end=" ")
# 这里是用format函数进行格式化输出控制,{2:2d}是给{2}这个位置两倍的空间,对齐乘法表
# 同时end是print函数内置方法,设置end=""print就不会进行换行操作
print(" ")
第九题
题目:暂停一秒输出。
程序分析:使用 time 模块的 sleep() 函数。
#coding = utf-8
import time
myD = {1: 'a', 2: 'b',3:'c',4:'d'}
for key, value in dict.items(myD):
print(key, value)
time.sleep(1) # 暂停 1 秒
第十题
题目:暂停一秒输出,并格式化当前时间。
程序分析:无。
#coding = utf-8
import time
print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time())))
# 暂停一秒
time.sleep(1)
print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time())))
第十一题
题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
程序分析:兔子的规律为数列1,1,2,3,5,8,13,21....
#coding = utf-8
f1 = 1
f2 = 1
for i in range(1,22):
print ('%12ld %12ld' % (f1,f2))
f1 = f1 + f2
f2 = f1 + f2
第十二题
题目:判断101-200之间有多少个素数,并输出所有素数。
程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。
#coding = utf-8
import math
def isPrimes1(n):
if n <= 1:
return False
for i in range(2,int(math.sqrt(n) + 1)):
if n % i == 0:
return False
return True
for i in range(1,100):
if (isPrimes1(i)):
print(f"{i}是素数")
第十三题
题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。
#coding = utf-8
#打印水仙花数。一个三位十进制数,其个位数字的立方+十位数字的立方+百位数字的立方=这个三位十进制数;例#如153=1**3+5**3+3**3
for i in range(100,1000):
ge=i%10
shi=i//10%10
bai=i//100
if ge**3+shi**3+bai**3==i:
print(i,end=" ")
第十四题
题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。
程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:
(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。
(2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。
(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。
#coding = utf-8
def reduceNum(n):
print ('{} = '.format(n), end=" ")
if not isinstance(n, int) or n <= 0 :
print ('请输入一个正确的数字 !')
exit(0)
elif n in [1] :
print ('{}'.format(n))
while n not in [1] : # 循环保证递归
for index in range(2, n + 1) :
if n % index == 0:
n //= index # n 等于 n//index
if n == 1:
print (index )
else : # index 一定是素数
print ('{} *'.format(index), end=" ")
break
reduceNum(90)
reduceNum(100)
第十五题
题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。
程序分析:程序分析:(a>b) ? a:b 这是条件运算符的基本例子。
#coding = utf-8
score = int(input('输入分数:\n'))
if score >= 90:
grade = 'A'
elif score >= 60:
grade = 'B'
else:
grade = 'C'
print('%d 属于 %s' % (score, grade))
第十六题
题目:输出指定格式的日期。
程序分析:使用 datetime 模块。
import time
import datetime
print(datetime.datetime.now().strftime('%Y-%m-%d'))
print(time.strftime('%Y-%m-%d',time.localtime()))
date1=datetime.date(2020,3,4)
print(date1)
date2=date1+datetime.timedelta(days=2)
print(date2)
第十七题
题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。
程序分析:利用 while 或 for 语句,条件为输入的字符不为 '\n'。
s=input('input a string:\n')
letters=0
space=0
digit=0
others=0
for c in s:
if c.isalpha():
letters+=1
elif c.isspace():
space+=1
elif c.isdigit():
digit+=1
else:
others+=1
print('char=%d,space=%d,digit=%d,others=%d'%(letters,space,digit,others))
第十八题
题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加由键盘控制。
程序分析:关键是计算出每一项的值。
num = int(input("请输入你要计算的十以内的数字"))
n = int(input("请输入你要计算的次数")) #即重叠数 每一次叠一个:2 22 222
l = 0
s = 0
z = 0
while l < n:
s += num*(10**l) #每一次数的和 2 + 20 + 200 +2000...l:即可理解为几位
l += 1
print(s)
z += s #再把每一个s 相加
print(z)
第十九题
题目:一个数如果恰好等于它的因子之和,这个数就称为"完数"。例如6=1+2+3.编程找出1000以内的所有完数。
#coding = utf-8
a = [] # 创建空列表用于储存因子
for i in range(2, 1000): # 取除数
for j in range(1, i): # 取小于除数的数作为被除数
if i % j == 0: # 如果两数相除,取余为0,也就是能整除,说明是因子
a.append(j) # 将因子储存在列表里
if sum(a) == i: # 当除数为i的情况完成后,将列表中的数求和,看是否满足因子相加等于除数的条件
print(f"{i}是完数,因子包括{a}") # 若符合,则输出完数和因子
a.clear() # 将列表元素清除,进行下一个(i+1)的情况
第二十题
题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?
#coding = utf-8
Sn = 100.0
Hn = Sn / 2
for n in range(2,11):
Sn += 2 * Hn
Hn /= 2
print('Total of road is %f' % Sn)
print('The tenth is %f meter' % Hn)
课本作业
1.
import sys
Zero = [" *** ",
" * * ",
"* *",
"* *",
"* *",
" * * ",
" *** "]
One = [" * ", "** ", " * ", " * ", " * ", " * ", "***"]
Two = [" *** ", "* *", "* * ", " * ", " * ", "* ", "*****"]
Three = [" *** ", "* *", " *", " ** ", " *", "* *", " *** "]
Four = [" * ", " ** ", " * * ", "* * ", "******", " * ",
" * "]
Five = ["*****", "* ", "* ", " *** ", " *", "* *", " *** "]
Six = [" *** ", "* ", "* ", "**** ", "* *", "* *", " *** "]
Seven = ["*****", " *", " * ", " * ", " * ", "* ", "* "]
Eight = [" *** ", "* *", "* *", " *** ", "* *", "* *", " *** "]
Nine = [" ****", "* *", "* *", " ****", " *", " *", " *"]
Digits = [Zero, One, Two, Three, Four, Five, Six, Seven, Eight, Nine]
try:
digits = sys.argv[1]
row = 0
while row < 7:
line = ""
column = 0
while column < len(digits):
number = int(digits[column])
digit = Digits[number]
line += digit[row] + " "
column += 1
print(line)
row += 1
except IndexError:
print("usage: bigdigits.py <number>")
except ValueError as err:
print(err, "in", digits)
2.
import sys
Zero = [" *** ", " * * ", "* *", "* *", "* *",
" * * ", " *** "]
One = [" * ", "** ", " * ", " * ", " * ", " * ", "***"]
Two = [" *** ", "* *", "* * ", " * ", " * ", "* ", "*****"]
Three = [" *** ", "* *", " *", " ** ", " *", "* *", " *** "]
Four = [" * ", " ** ", " * * ", "* * ", "******", " * ",
" * "]
Five = ["*****", "* ", "* ", " *** ", " *", "* *", " *** "]
Six = [" *** ", "* ", "* ", "**** ", "* *", "* *", " *** "]
Seven = ["*****", " *", " * ", " * ", " * ", "* ", "* "]
Eight = [" *** ", "* *", "* *", " *** ", "* *", "* *", " *** "]
Nine = [" ****", "* *", "* *", " ****", " *", " *", " *"]
Digits = [Zero, One, Two, Three, Four, Five, Six, Seven, Eight, Nine]
try:
digits = sys.argv[1]
row = 0
while row < 7:
line = ""
column = 0
while column < len(digits):
number = int(digits[column])
digit = Digits[number]
for c in digit[row]:
if c == "*":
c = str(number)
line += c
line += " "
column += 1
print(line)
row += 1
except IndexError:
print("usage: bigdigits.py <number>")
except ValueError as err:
print(err, "in", digits)
3.
import random
articles = ["the", "a", "another", "her", "his"]
subjects = ["cat", "dog", "horse", "man", "woman", "boy", "girl"]
verbs = ["sang", "ran", "jumped", "said", "fought", "swam", "saw",
"heard", "felt", "slept", "hopped", "hoped", "cried",
"laughed", "walked"]
adverbs = ["loudly", "quietly", "quickly", "slowly", "well", "badly",
"rudely", "politely"]
for _ in [1, 2, 3, 4, 5]:
article = random.choice(articles)
subject = random.choice(subjects)
verb = random.choice(verbs)
if random.randint(0, 1) == 0:
print(article, subject, verb)
else:
adverb = random.choice(adverbs)
print(article, subject, verb, adverb)
4.
import cmath
import math
import sys
def get_float(msg, allow_zero):
x = None
while x is None:
try:
x = float(input(msg))
if not allow_zero and abs(x) < sys.float_info.epsilon:
print("zero is not allowed")
x = None
except ValueError as err:
print(err)
return x
print("ax\N{SUPERSCRIPT TWO} + bx + c = 0")
a = get_float("enter a: ", False)
b = get_float("enter b: ", True)
c = get_float("enter c: ", True)
x1 = None
x2 = None
discriminant = (b ** 2) - (4 * a * c)
if discriminant == 0:
x1 = -(b / (2 * a))
else:
if discriminant > 0:
root = math.sqrt(discriminant)
else: # discriminant < 0
root = cmath.sqrt(discriminant)
x1 = (-b + root) / (2 * a)
x2 = (-b - root) / (2 * a)
equation = ("{0}x\N{SUPERSCRIPT TWO} + {1}x + {2} = 0"
" \N{RIGHTWARDS ARROW} x = {3}").format(a, b, c, x1)
if x2 is not None:
equation += " or x = {0}".format(x2)
print(equation)
5.
import sys
def main():
maxwidth = 100
print_start()
count = 0
while True:
try:
line = input()
if count == 0:
color = "lightgreen"
elif count % 2:
color = "white"
else:
color = "lightyellow"
print_line(line, color, maxwidth)
count += 1
except EOFError:
break
print_end()
def print_start():
print("<table border='1'>")
def print_line(line, color, maxwidth):
print("<tr bgcolor='{0}'>".format(color))
fields = extract_fields(line)
for field in fields:
if not field:
print("<td></td>")
else:
number = field.replace(",", "")
try:
x = float(number)
print("<td align='right'>{0:d}</td>".format(round(x)))
except ValueError:
field = field.title()
field = field.replace(" And ", " and ")
if len(field) <= maxwidth:
field = escape_html(field)
else:
field = "{0} ...".format(
escape_html(field[:maxwidth]))
print("<td>{0}</td>".format(field))
print("</tr>")
def extract_fields(line):
fields = []
field = ""
quote = None
for c in line:
if c in "\"'":
if quote is None: # start of quoted string
quote = c
elif quote == c: # end of quoted string
quote = None
else:
field += c # other quote inside quoted string
continue
if quote is None and c == ",": # end of a field
fields.append(field)
field = ""
else:
field += c # accumulating a field
if field:
fields.append(field) # adding the last field
return fields
def escape_html(text):
text = text.replace("&", "&")
text = text.replace("<", "<")
text = text.replace(">", ">")
return text
def print_end():
print("</table>")
main()
第二十一题
题目:猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。
程序分析:采取逆向思维的方法,从后往前推断。
#coding = utf-8
'''
思想:第十天早上是一个,第九天早上是2*(1+1)。倒序依次向前累加
'''
def SumT():
x=1
for i in range(9,0,-1):
y=2*(x+1)
x=y
print(f"总的桃子数{y}")#总的桃子数1534
if __name__=="__main__":
SumT()
第二十二题
题目:两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。有人向队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。
#coding = utf-8
for i in range(ord('x'), ord('z') + 1):
for j in range(ord('x'), ord('z') + 1):
if i != j:
for k in range(ord('x'), ord('z') + 1):
if (i != k) and (j != k):
if (i != ord('x')) and (k != ord('x')) and (k != ord('z')):
print('order is a -- %s\t b -- %s\tc--%s' % (chr(i), chr(j), chr(k)))
#order is a -- z b -- x c--y
第二十三题
打印出如下图案(菱形)
*
***
*****
*******
*****
***
*
for i in range(4): #先打印上面的三角,即前四行
for j in range(3 - i):
print(end=' ') # 打印每一行前面的空格,单引号里面要加入一个空格
for w in range(2 * i + 1): #开始打印*
print('*', end=('')) # end=('') # 表示在每一次小循环里不换行进行输出
print('') # 小循环结束后,实现换行输出
for i in range(3): #打印后三行,方法如上
for j in range(i + 1):
print(end=' ')
for x in range(5 - 2 * i):
print('*', end='')
print('')
第二十四题
题目:有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列的前20项之和。
程序分析:请抓住分子与分母的变化规律。
#coding = utf-8
n = int(input("请输入求和项数:"))
n_sum = 0 # 记录前n项和
a = 1 # 分母
b = 2 # 分子
for i in range(n):
n_sum += b / a
a, b = b, a + b
print("数列前 %d 项和为 %f" % (n, n_sum))
第二十五题
题目:求1+2!+3!+...+20!的和。
程序分析:此程序只是把累加变成了累乘。
#coding = utf-8
s=0
t=1
for i in range(1,21):
t=t*i
s=s+t
print(s)
#2561327494111820313
第二十六题
题目:利用递归方法求5!。
程序分析:递归公式:fn=fn_1*4!
def fun(n):
if n!=1:
return n*fun(n-1)
else:
return 1
if __name__=="__main__":
num=int(input())
print(fun(num))
第二十七题
题目:利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。
#coding = utf-8
str1=input()
strLen=len(str1)
def output(str1,strLen):
if strLen==0:
return
print(str1[strLen-1])
output(str1,strLen-1)
output(str1,strLen)
程序分析:无。
第二十八题
题目:有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个人多大?
程序分析:利用递归的方法,递归分为回推和递推两个阶段。要想知道第五个人岁数,需知道第四人的岁数,依次类推,推到第一人(10岁),再往回推。
#coding = utf-8
def age(n):
if n == 1: c = 10
else: c = age(n - 1) + 2
return c
print (age(5))
第二十九题
题目:给一个不多于5位的正整数,要求:一、求它是几位数,二、逆序打印出各位数字。
程序分析:学会分解出每一位数。
#coding = utf-8
num=input()
len1=len(num)
print(f"{num}的长度是{len1}")
print(f"{num}的逆序是:")
for i in range(0,len1):
print(num[len1-1-i],end=" ")
第三十题
题目:一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。
程序分析:无。
#coding = utf-8
num=input()
n=num
num=list(num)
num1=''.join(num)
num.reverse()
num2=''.join(num)
if num1==num2:
print(f"{n}是回文数")
else:
print(f"{n}不是回文数")
第三十一题
题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母。
程序分析:用情况语句比较好,如果第一个字母一样,则判断用情况语句或if语句判断第二个字母。
#coding = utf-8
letter = input("please input:")
if letter == 'S':
print('please input second letter:')
letter = input("please input:")
if letter == 'a':
print('Saturday')
elif letter == 'u':
print('Sunday')
else:
print('data error')
elif letter == 'F':
print('Friday')
elif letter == 'M':
print('Monday')
elif letter == 'T':
print('please input second letter')
letter = input("please input:")
if letter == 'u':
print('Tuesday')
elif letter == 'h':
print('Thursday')
else:
print('data error')
elif letter == 'W':
print('Wednesday')
else:
print('data error')
第三十二题
题目:按相反的顺序输出列表的值。
程序分析:无。
#coding = utf-8
lista=[1,2,3,4,5,6]
for i in lista[::-1]:
print(i,end=" ")
第三十三题
题目:按逗号分隔列表。
程序分析:无。
#coding = utf-8
lista=[1,2,3,4,5]
s1 = ','.join(str(n) for n in lista)
print (s1)
第三十四题
题目:练习函数调用。
程序分析:使用函数,输出三次 RUNOOB 字符串。
#coding = utf-8
def hello_runoob():
print('RUNOOB')
def hello_runoobs():
for i in range(3):
hello_runoob()
if __name__ == '__main__':
hello_runoobs()
第三十五题
题目:文本颜色设置。
程序分析:无。
class bcolors:
HEADER = '\033[95m'
OKBLUE = '\033[94m'
OKGREEN = '\033[92m'
WARNING = '\033[93m'
FAIL = '\033[91m'
ENDC = '\033[0m'
BOLD = '\033[1m'
UNDERLINE = '\033[4m'
print (bcolors.WARNING + "警告的颜色字体?" + bcolors.ENDC)
第三十六题
题目:求100之内的素数。
程序分析:无。
#coding = utf-8
# 用户输入数据
lower = int(input("输入区间最小值: "))
upper = int(input("输入区间最大值: "))
for num in range(lower, upper + 1):
# 素数大于 1
if num > 1:
for i in range(2, num):
if (num % i) == 0:
break
else:
print(num)
第三十七题
题目:对10个数进行排序。
程序分析:可以利用选择法,即从后9个比较过程中,选择一个最小的与第一个元素交换,下次类推,即用第二个元素与后8个进行比较,并进行交换。
#coding = utf-8
lista=[2,4,6,8,10,1,3,5,7,9]
lista.sort()
for i in range(0,10):
print(lista[i],end=" ")
第三十八题
题目:求一个3*3矩阵主对角线元素之和。
程序分析:利用双重for循环控制输入二维数组,再将a[i][i]累加后输出。
if __name__ == '__main__':
a = []
sum = 0.0
for i in range(3):
a.append([])
for j in range(3):
a[i].append(float(input("input num:\n")))
for i in range(3):
sum += a[i][i]
print (sum)
第三十九题
题目:有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。
程序分析:首先判断此数是否大于最后一个数,然后再考虑插入中间的数的情况,插入后此元素之后的数,依次后移一个位置。
n = 5
list = [1, 2, 3, 6, 7, 8, 9, 10, 11, 13]
list.append(n)
print(list)
for i in range (len(list)-2,0,-1):
if list[i]>list[i+1]:
list[i],list[i+1]=list[i+1],list[i]
print(list)
第四十题
题目:将一个数组逆序输出。
程序分析:用第一个与最后一个交换。
if __name__ == '__main__':
a = [9,6,5,4,1]
N = len(a)
print (a)
for i in range(len(a) // 2):
a[i],a[N - i - 1] = a[N - i - 1],a[i]
print (a)