Java教程

第7,8天作业

本文主要是介绍第7,8天作业,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

    
作业1:有一堆硬币,每次只能拿一个或者两个,求最少多少次可以拿完硬币
        [10, 8, 5, 3, 27, 99]

num = 0
ls = [10, 8, 5, 3, 27, 99]
for i in ls:
    a = i % 2
    if a == 0:
        num = i // 2 + num
    else:
        num = i // 2 + num + 1
print("需要取%s次"%(num))



C:\Users\山己几>python D:\day2\有一堆硬币.py
需要取78次

C:\Users\山己几>


作业2:如果两个素数之差为2,这样的两个素数就叫作"孪生数",找出100以内的所有"孪生数".

ls = []
for i in range(2, 101):
	flag = True
	for j in range(2, i):
		if i % j == 0:
			flag = False
			break
	if flag:
		ls.append(i)
index = 0
print(ls)
while index < len(ls) - 1:
	first = ls[index]
	second = ls[index + 1]
	if second - first == 2:
		print(f"{first}和{second}之间是孪生素数")
	index += 1



C:\Users\山己几>python D:\day2\孪生数.py
[2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97]
3和5之间是孪生素数
5和7之间是孪生素数
11和13之间是孪生素数
17和19之间是孪生素数
29和31之间是孪生素数
41和43之间是孪生素数
59和61之间是孪生素数
71和73之间是孪生素数

作业3:给定一个列表,求最大值(不能使用系统api),求最小值,求平均值、求和

ls = [1,2,3,4,5,6,7,8]
print("列表",ls)
num_max = ls[0]
num_min = ls[0]
num_and = 0
for i in range(1,len(ls)):
	if num_max < ls[i]:
		num_max = ls[i]
	elif num_min > ls[i]:
		num_min = ls[i]
	else:
		pass
print("最大值:",num_max)
print("最小值:",num_min)
for i in ls:
	num_and += i
print("和:",num_and)
num_average = num_and/len(ls)
print("平均值:",num_average)




C:\Users\山己几>python D:\day2\给定一个列表,求最大值(不能使用系统api),求最小值,求平均值、求和.py
列表 [1, 2, 3, 4, 5, 6, 7, 8]
最大值: 8
最小值: 1
和: 36
平均值: 4.5

作业4:将list中的重复数据去重,至少使用两种方案

#1.将列表转换成为集合再转换成为列表
a = [1,2,36,1,2,88,98,56]
#将转换前的列表输出
print("去重前:",a)
#b是转换后的新列表
b = list(set(a))
print("去重后:",b)

#2.利用循环进行去重
j = []
for i in a:
	if i not in j:
		j.append(i)
print("去重后:",j)

作业5:两个列表进行合并操作

 

作业6: 使用列表判断一个列表是否在另外一个列表中

#根据是否存在交集来判断列表是否在另一个列表中,若存在交集,则自然证明存在
a = [1,2,3,6,8,9,10,11,12]
b = [1,2,3]
j = list(set(a).intersection(set(b)))
print(j)

作业7:列表的反转  列表的排序

作业8.如何将0-10随机存入列表中

​
import random


ls = []

for i in range(10):
	ls.append(random.randint(0, 10))


print(ls)

​


作业1:完成一个登录注册案例(要求使用容器保存数据)

import sys


# users保存所有注册成功的用户
users = []
while True:
	print("欢迎登录我们的用户管理系统")
	print("\t\t 1、用户注册")
	print("\t\t 2、用户登录")
	print("\t\t 3、退出系统")
	choice = input("请选择您的操作:")

	if choice == "1":
		while True:
			print("欢迎进入到用户注册页面")
			username = input("请输入用户名称:")
			password = input("请输入用户密码:")
			confirm_password = input("请再次确认密码:")

			# 数据校验
			# 用户名称不能为空
			if username == None or len(username) == 0:
				print("对不起,用户为空")
				continue
			# 用户名称不能重复
			flag = False
			for u in users:
				if u.get("username") == username:
					print("对不起,该用户已经存在,请重新注册")
					flag = True
					break
			if flag:
				continue
			# 密码长度不能少于3位
			if len(password) < 3:
				print("对不起,密码长度不能少于3位")
				continue
			# 两次密码不一致
			if password != confirm_password:
				print("两次密码不一致")
				continue

			# 最后如何保存用户名称和密码
			user = {"username": username, "password": password}
			users.append(user)
			print("用户注册成功,请登录")
			break
	elif choice == "2":
		print("欢迎进入到用户登录页面")
		username = input("请输入用户名称:")
		password = input("请输入用户密码:")

		# 判断用户名和密码是否存在于users
		for user in users:
			if user["username"] == username and user.get("password") == password:
				print("恭喜您,{},登录成功".format(username))
			else:
				print("对不起,登录失败,请重新登录~~")

	elif choice == "3":
		sys.exit()
	else:
		print("输入有误,请重新选择")







D:\day2>python python完成一个登录注册案例(要求使用容器保存数据).py
欢迎登录我们的用户管理系统
                 1、用户注册
                 2、用户登录
                 3、退出系统
请选择您的操作:1
欢迎进入到用户注册页面
请输入用户名称:username
请输入用户密码:password
请再次确认密码:password
用户注册成功,请登录
欢迎登录我们的用户管理系统
                 1、用户注册
                 2、用户登录
                 3、退出系统
请选择您的操作:3

作业2:给定一个10个元素的列表,请完成排序(注意,不要使用系统api)

 

作业3:求  a+aa+aaa+.......+aaaaaaaaa=?其中a为1至9之中的一个数,项数也要可以指定。

num = input("请输入要相加的数字:")
count = int(input("请输入想加的个数:"))
a = []
s = 0
for i in range(1,count+1):
	a.append(num*i)
	s += int(num*i)
print(f"{s}={'+'.join(a)}")






D:\day2>python "求  a+aa+aaa+.......+aaaaaaaaa=其中a为1至9之中的一个数,项数也要可以指定。.py"
请输入要相加的数字:9
请输入想加的个数:9
1111111101=9+99+999+9999+99999+999999+9999999+99999999+999999999

作业4:合并两个有序数组,合并后还是有序列表

list1 = [1,2,3,4,5,6,7]
list2 = [8,9,10,11,12,13]
result = []
while list1 and list2:
 if list1[0] < list2[0]:
  result.append(list1[0])
  list1.remove(list1[0])
 else:
  result.append(list2[0])
  list2.remove(list2[0])
for i in list2:
 result.append(i)
result.sort()
print(result)





D:\day2>python 合并两个有序数组,合并后还是有序列表.py偶数都放在奇数元素之前.py
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13]

作业5:给定一个非负整数数组A,将该数组中的所有偶数都放在奇数元素之前

​
def sortArray(A:list) -> list:
    reorder = []
    for i in A:
        if i % 2 == 0:
            reorder.append(i)
    for i in A:
        if i % 2 != 0:
            reorder.append(i)
    return reorder
 
print(sortArray([3,1,2,4]))




D:\day2>python 给定一个非负整数数组A,将该数组中的所有偶数都放在奇数元素之前.py
[2, 4, 3, 1]

​

作业6:将10进制数据转换为二进制,并且统计其中的0和1的数量

def duble():
	n=input('请输入终止值:')
	a=[]
	i=1
	while i<=int(n):
		d={}
		b=list(bin(i))
		m=0
		for j in b:
			if j=='1':
				m+=1
		d[i]=m
		a.append(d)
		i+=1
	print(a)
duble()
def duble1():
	n=input('请输入要查询的数:')
	m=0
	for j in list(bin(int(n))):
		if j=='1':
			m+=1
	print(m)
	duble1()
duble1()



D:\day2>python 将10进制数据转换为二进制,并且统计其中的0和1的数量.py元素之前.py
请输入终止值:23
[{1: 1}, {2: 1}, {3: 2}, {4: 1}, {5: 2}, {6: 2}, {7: 3}, {8: 1}, {9: 2}, {10: 2}, {11: 3}, {12: 2}, {13: 3}, {14: 3}, {15: 4}, {16: 1}, {17: 2}, {18: 2}, {19: 3}, {20: 2}, {21: 3}, {22: 3}, {23: 4}]
请输入要查询的数:6
2
请输入要查询的数:6
2
请输入要查询的数:7

作业7:给定一个数组,已知数组中的元素都是成对出现,
    现在数组中只有一个元素没有成对,请找出这个元素。
    [1,3,1,2,2,8,8]

nums = [1,3,1,2,2,8,8]
nums_dict={}
for i in nums:
    nums_dict.setdefault(i,0)
    nums_dict[i]+=1
for i in nums_dict:
    if nums_dict[i]==1:
        print(f'只出现一次的数字为{i}')




D:\day2>python 给定一个数组,已知数组中的元素都是成对出现,.py在奇数元素之前.py可以指定。.py"
只出现一次的数字为3

D:\day2>

作业(选做题):
    某个人进入如下一个棋盘中,要求从左上角开始走,最后从右下角出来(要求只能前进,不能后退),
    问题:共有多少种走法?
    
    0 0 0 0 0 0 0 0

    0 0 0 0 0 0 0 0

    0 0 0 0 0 0 0 0

    0 0 0 0 0 0 0 0

    0 0 0 0 0 0 0 0
 

这篇关于第7,8天作业的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!