当前位置: 首页 > news >正文

Python作业答疑

1. 旋转字符串

1.1 问题描述

给定一个字符串(以字符数组的形式)和一个偏移量,根据偏移量原地从左向右旋转字符串。

1.2 问题示例

输入str="abcdefg"offset=3,输出"efgabcd"

输入str="abcdefg"offset=0,输出"abcdefg"

输入str="abcdefg"offset=1,输出"gabcdef",返回旋转后的字符串。

输入str="abcdefg"offset =2,输出"fgabcde",返回旋转后的字符串。

提示:在 Python 中,字符串是不能进行修改的,如果要修改字符串中的字符,可以先转换成列表。

要求至少使用到 2 种以上的的解决方法。

1.3 解题思路

1.3.1 使用字符串的切片一
def rotate_str(s, offset):if len(s) > 0:# 如果offset = offset % len(s)# 使用切片s = s[-offset:] + s[0:len(s)- offset]return ss = input("请输入一个字符串")
offset = int(input("请输入偏移量"))
s = rotate_str(s, offset)
print(s)
1.3.2 使用列表的 popinsert方法
def rotate_str_(s, offset):if len(s) > 0:offset = offset % len(s)# 转换成列表lst = list(s)for i in range(offset):lst.insert(0, lst.pop())# 返回字符串    return "".join(lst)s = input("请输入一个字符串")
offset = int(input("请输入偏移量"))
s = rotate_str_(s, offset)
print(s)
1.3.3 使用字符串的切片二
def rotate_str_01(s, offset):if len(s) > 0:offset = offset % len(s)# 原字符串扩大 2 倍s = (s * 2)[len(s) - offset:2 * len(s) - offset]return ss = input("请输入一个字符串")
offset = int(input("请输入偏移量"))
s = rotate_str_01(s, offset)
print(s)

2. 相对排名

2.1 问题描述

根据N名运动员得分,找到相对等级和获得最高分前 3名的人,分别获得金牌、银牌和铜牌。N是正整数,并且不超过10 000。所有运动员的成绩都保证是独一无二的。

2.2 问题示例

输入运动员的得分 [5,4,3,2,1],输出["金牌","银牌","铜牌","4","5"],前3名运动员得分较高,根据得分依次获得金牌、银牌和铜牌。对于后两名运动员,根据分数输出相对等级。

输入运动员的成绩[6,5,1,8,4,3],输出 ["银牌","铜牌",6,"金牌",4,5]

提示:输入的运动员成绩不一定刚开始就是有序的。

2.3 解题思路

#运动员的成绩
scores = [6, 5, 1, 8, 4, 3]
# 由高向低排序成绩
sort_scores = sorted(scores, reverse=True)
# 保存每一个成绩的名次
dic = {}
for i in range(len(sort_scores)):if i == 0:dic[sort_scores[i]] = "金牌"elif i == 1:dic[sort_scores[i]] = "银牌"elif i == 2:dic[sort_scores[i]] = "铜牌"else:dic[sort_scores[i]] = i + 1res = []
for i in scores:res.append(dic[i])
print(res)
'''
['银牌', '铜牌', 6, '金牌', 4, 5]
'''

3. 下一个更大的数

3.1 问题描述

  • 两个不重复的数组nums1nums2,其中nums1nums2的子集。
  • nums2的相应位置找到nums1所有元素的下一个更大数字。nums1中的数字x的下一个更大数字是nums2x右边第1个更大的数字。
  • 如果它不存在,则为此数字输出-1nums1nums2中的所有数字都是唯一的,nums1nums2的长度不超过1000

3.2 问题示例

输入nums1=[4,1,2]nums2=[1,3,4,2],输出[-1,3,-1]

  • 对于第1个数组中的数字4,在第2个数组中找不到下一个更大的数字,因此输出-1
  • 对于第1个数组中的数字1,第2个数组中的下一个更大数字是3
  • 对于第1个数组中的数字2,第2个数组中没有下一个更大的数字,因此输出-1

提示:注意审题。

3.3 解题思路

3.3.1 使用列表的index方法

nums1 = [4, 1, 2]
nums2 = [1, 3, 4, 2]res = []
for i in nums1:# 在nums1中的数字在nums2中的位置pos = nums2.index(i)flag = -1# 是否存在比自己大的数字if len(nums2)-1 >= pos + 1 is not None and nums2[pos + 1] > i:flag = nums2[pos + 1]res.append(flag)print(res)
'''
输出结果
[-1, 3, -1]
'''

3.3.2 使用栈

nums1 = [4, 1, 2]
nums2 = [1, 3, 4, 2]
# 保存结果
res = {}
# 栈
stack = []
for i in nums2:# 查找栈顶数据是否比自己小if len(stack) > 0 and stack[-1] < i:res[stack[-1]] = istack.pop()stack.append(i)
for i in stack:res[i] = -1for i in nums1:print(res[i], end=" ")

提示,也可以先把nums2中的数字按先后顺序压入到栈中,然后提取栈顶数据,

nums1 = [4, 1, 2]
nums2 = [1, 3, 4, 2]res = {}
stack = []
# 把nums2中的数字全部压入栈中
for i in nums2:stack.append(i)
pre_top = None
for i in range(len(stack)):# 提取栈顶数据top = stack[-1]if pre_top is not None and top < pre_top:res[top] = pre_topelse:res[top] = -1     pre_top = stack.pop()
for i in nums1:print(res[i], end=" ")

4. 点积

4.1 问题描述

给出2个列表,求它们的点积。

4.2 问题示例

输入为A=[1,1,1]B=[2,2,2],输出为61*2+1*2+1*2=6。输入为A=[3,2]B=[2,3,3],输出为-1,没有点积。

提求:至少 2 种方法实现。直接使用列表和numpy

4.3 解题思路

4.3.1 使用列表
a = [1, 1, 1]
b = [2, 2, 2]
res = 0
if len(a) == len(b):for i in range(len(a)):res += a[i] * b[i]
print(res)
4.3.2 使用 numpy
import numpy as np
a = [1, 1, 1]
b = [2, 2, 2]
res = 0
a = np.array(a)
b = np.array(b)
res = a.dot( b)
print(res)

5. 查询区间

5.1 问题描述

给定一个包含若干个区间的List列表,长度是1000,如[500,1500][2100,3100]。给定一个number,判断number是否在这些区间内,返回TrueFalse

5.2 问题示例

输入是lst=[[100,1100],[1000,2000],[5500,6500]]number=6000,输出是True,因为6000在区间[5500,6500]

输入是lst=[[100,1100],[2000,3000]]number=3500,输出是False,因为3500不在lst的任何一个区间中。

5.3 解题思路

lst = [[100, 1100], [1000, 2000], [5500, 6500]]
number = 6000
is_exist = False
for i in lst:if number >= min(i) and number <= max(i):is_exist = Truebreak
print(is_exist)

6. 新郎和新娘

6.1 问题描述

有三对情侣结婚,假设三个新郎为A、B、C,三个新娘为X、Y、Z

有参加婚礼的人搞不清谁和谁结婚,所以去询问了这六位新人中的三位,得到的回答为:

  • 新郎A说他要和新娘X结婚;
  • 新娘X说她的未婚夫是新郎C
  • 而新郎C说他要和新娘Z结婚。
  • 听到这样的回答后,提问者知道他们都是在开玩笑,说的都是假话,但他仍搞不清谁和谁结婚。

现在请编程求出到底哪位新郎和哪位新娘结婚。

6.2 解题思路

xin_lang = ["A", "B", "C"]
for x in xin_lang:for y in xin_lang:for z in xin_lang:if x != xin_lang[0] and x != xin_lang[2] and z != xin_lang[2] and x != y and x != z and y != z:print("X", x)print("Y", y)print("Z", z)

7. 编写求平均分的函数

7.1 问题描述

输入学生的成绩,把学生的成绩传入自定义函数,函数输出学生成绩的平均分。

提示:学生人数不限。自定义函数接收一个列表,输出平均分。

7.2 解题思路

def get_avg(lst):s = 0for i in lst:s += ireturn s / len(lst)scores = []
for i in range(5):s = int(input("请输入学生成绩"))scores.append(s)res = get_avg(scores)
print(res)

8.提取单词

8.1 问题描述

如有一个字符串”this is a test”请根据用户指定的单词位置,输出单词。如 用户输入 4 ,则输出 test。

提示:必须通过调用自定义函数实现效果。

8.2 解题思路

def get_word(s, pos):lst = s.split(" ")return lst[pos - 1]
#
s = "this is a test"
w = get_word(s, 4)
print(w)

9. 求年龄

9.1 问题描述

有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁,问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁,最后问第一个人,他说是10岁。请问第五个人多大?

9.2 解题思路

age=10
def get_age(age):for i in range(4):age=age+2return  age
print (get_age(age))

10. 回文数函数

10.1 问题描述

实现判断一个数是不是回文数的函数。

10.2 解题思路

def get_huiwei(num):if str(num)[::-1] == str(num):return Truereturn False
print(get_huiwei(12312))

相关文章:

Python作业答疑

1. 旋转字符串 1.1 问题描述 给定一个字符串&#xff08;以字符数组的形式&#xff09;和一个偏移量&#xff0c;根据偏移量原地从左向右旋转字符串。 1.2 问题示例 输入str"abcdefg"&#xff0c;offset3&#xff0c;输出"efgabcd"。 输入str"ab…...

计算机网络实用工具之Hydra

简介 Hydra 是一个并行登录破解程序&#xff0c;支持多种协议进行攻击。它非常快速且灵活&#xff0c;并且很容易添加新模块。 该工具使研究人员和安全顾问能够展示远程未经授权访问系统是多么容易。 目前该工具支持以下协议&#xff1a; Asterisk, AFP, Cisco AAA, Cisco au…...

AUTOSAR 入门

前言 AUTOSAR是什么Vector DaVinci 工具功能快捷键合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants 创建一个自定义列表如何创建一个注脚注释也是必…...

新版IDEA中,module模块无法被识别,类全部变成咖啡杯无法被识

新版IDEA中&#xff0c;module模块无法被识别&#xff0c;类全部变成咖啡杯无法被识 如下图&#xff1a; 解决方法&#xff1a;java的Directory文件没有被设置为根目录&#xff0c;解决方法如下&#xff1a; 这是方法之一&#xff0c;还有很多的原因 可能的原因&#xff1a; …...

vue.js el-table 动态单元格列合并

一、业务需求&#xff1a; 一个展示列表&#xff0c;表格中有一部分列是根据后端接口动态展示&#xff0c;对于不同类型的数据展示效果不一样。如果接口返回数据是’类型1‘的&#xff0c;则正常展示&#xff0c;如果是’类型2‘的数据&#xff0c;则合并当前数据的动态表格。…...

word模板导出word文件

前期准备工作word模板 右键字段如果无编辑域 ctrlF9 一下&#xff0c;然后再右键 wps 直接 ctrlF9 会变成编辑域 pom.xml所需依赖 <dependencies> <!--word 依赖--> <dependency><groupId>fr.opensagres.xdocreport</groupId><artifactId…...

debianubuntu的nvidia驱动升级

背景 给出的机器的驱动版本不符合要求&#xff0c;使用自定义的驱动版本。 前置 如果使用nvidia官方的.run安装的驱动包&#xff0c;可以使用系统自带的nvidia-uninstall命令卸载比较方便&#xff0c;不建议使用apt pruge nvidia-*命令删除。会带来其他的问题。 卸载完成之…...

【开源视频联动物联网平台】视频接入网关的用法

视频接入网关是一种功能强大的视频网关设备&#xff0c;能够解决各种视频接入、视频输出、视频转码和视频融合等问题。它可以在应急指挥、智慧融合等项目中发挥重要作用&#xff0c;与各种系统进行对接&#xff0c;解决视频能力跨系统集成的难题。 很多视频接入网关在接入协议…...

【bug排查解决】现象级延迟8-10s

业务背景 最近公司在做物联网相关的项目&#xff0c;调试过程中发现好玩的bug。 首先一个数据采集场景&#xff0c;plc采集数据全链路&#xff1a; kepServer&#xff08;kepserver IOT gateway&#xff09; -> emqx &#xff08;查看日志&#xff09;-> iot服务 -> 业…...

【人生感悟】不能对一个人太好是有心理学原理的

1、不能对一个人太好是有心理学原理的&#xff0c;当你长期友善对待一个人时&#xff0c;如果这个人认知程度不是很高&#xff0c;层次稍微的偏低&#xff0c;那他可能直接把你的友善理解为理所应当&#xff0c;甚至是你在讨好他&#xff0c;还会把你们之间的关系理解成他是高于…...

动态规划学习——最长回文子序列,让字符串变成回文串的最小插入次数

一&#xff0c;最长回文串 1.题目 给你一个字符串 s &#xff0c;找出其中最长的回文子序列&#xff0c;并返回该序列的长度。 子序列定义为&#xff1a;不改变剩余字符顺序的情况下&#xff0c;删除某些字符或者不删除任何字符形成的一个序列。 示例 1&#xff1a; 输入&…...

CSS新手入门笔记整理:CSS列表样式

列表项符号&#xff1a;list-style-type 在HTML中&#xff0c;对于有序列表和无序列表的列表项符号&#xff0c;都是使用type属性来定义的。 语法 list-style-type:取值; list-style-type属性是针对ol或者ul元素的&#xff0c;而不是li元素。 有序列表属性 属性值 说明 …...

12月07日,每日信息差

以下是2023年12月07日的11条信息差 第一、社交媒体公司X计划在日本成立应用开发团队 第二、造车进程加快&#xff0c;小米汽车在多地招聘零售门店主管&#xff0c;零售门店主管工作地点涉及武汉、重庆、长沙、郑州、佛山、东莞、厦门等城市 第三、我国西南地区首座百万千瓦级…...

spring mvc理解

spring mvc M&#xff1a;model 模型 V&#xff1a;view 视图 C&#xff1a;controller 控制器 S: service 服务处理 D: Dao 数据持久化 视图 我理解就是web页面&#xff0c;帮助用户调用后端接口。 前后端分离之后&#xff0c;view似乎就和后端没什么关系了。 模型 格式…...

HTML-标签之文字排版、图片、链接、音视频

1、标签语法 HTML超文本标记语言——HyperText Markup Language 超文本是链接标记也叫标签&#xff0c;带尖括号的文本 2、HTML基本骨架 HTML基本骨架是网页模板 html&#xff1a;整个网页head&#xff1a;网页头部&#xff0c;存放给浏览器看的代码&#xff0c;例如CSSbody…...

圣诞将至—C语言圣诞树代码来啦

文章目录 圣诞将至—C实现语言圣诞树源码 圣诞将至—C实现语言圣诞树 圣诞树 源码 #define _CRT_SECURE_NO_WARNINGS#include <stdio.h> #include <math.h> #include <stdlib.h> #include <windows.h> #include <time.h> #define PI 3.14159265…...

Git常用命令#merge分支合并

要查看所有分支&#xff0c;包括本地和远程仓库的分支&#xff0c;可以使用以下命令&#xff1a; 1.查看分支 1.1 查看本地分支 git branch这个命令会列出本地所有的分支&#xff0c;当前所在的分支会有 * 标记。 1.2 查看远程分支 git branch -r这个命令会列出远程仓库的分…...

Windows server 2019 域环境部署

环境准备 准备3台服务器&#xff0c;配置都是8g2核&#xff0c;50g硬盘&#xff0c;操作系统版本Windows Server 2019 Datacenter 域服务器&#xff1a;adc&#xff0c;192.168.56.120服务器1&#xff1a;server1:&#xff0c;192.168.56.121服务器2&#xff1a;server2&…...

Cocos Creator加入图片没有被识别

原因&#xff0c;需要更换类型&#xff0c;选择下图中的类型...

java double类型保留两位小数并去除后面多余的0

public static void main(String[] args) {double value9.100001;//保留两位小数String format String.format("%.2f", value);//去除多余的0String strValue new BigDecimal(format).stripTrailingZeros().toPlainString();System.out.println("strValue &q…...

postgresql|数据库|只读用户的创建和删除(备忘)

CREATE USER read_only WITH PASSWORD 密码 -- 连接到xxx数据库 \c xxx -- 授予对xxx数据库的只读权限 GRANT CONNECT ON DATABASE xxx TO read_only; GRANT USAGE ON SCHEMA public TO read_only; GRANT SELECT ON ALL TABLES IN SCHEMA public TO read_only; GRANT EXECUTE O…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)

设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile&#xff0c;新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

Module Federation 和 Native Federation 的比较

前言 Module Federation 是 Webpack 5 引入的微前端架构方案&#xff0c;允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...

Linux-07 ubuntu 的 chrome 启动不了

文章目录 问题原因解决步骤一、卸载旧版chrome二、重新安装chorme三、启动不了&#xff0c;报错如下四、启动不了&#xff0c;解决如下 总结 问题原因 在应用中可以看到chrome&#xff0c;但是打不开(说明&#xff1a;原来的ubuntu系统出问题了&#xff0c;这个是备用的硬盘&a…...

项目部署到Linux上时遇到的错误(Redis,MySQL,无法正确连接,地址占用问题)

Redis无法正确连接 在运行jar包时出现了这样的错误 查询得知问题核心在于Redis连接失败&#xff0c;具体原因是客户端发送了密码认证请求&#xff0c;但Redis服务器未设置密码 1.为Redis设置密码&#xff08;匹配客户端配置&#xff09; 步骤&#xff1a; 1&#xff09;.修…...

Java + Spring Boot + Mybatis 实现批量插入

在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法&#xff1a;使用 MyBatis 的 <foreach> 标签和批处理模式&#xff08;ExecutorType.BATCH&#xff09;。 方法一&#xff1a;使用 XML 的 <foreach> 标签&#xff…...

Java毕业设计:WML信息查询与后端信息发布系统开发

JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发&#xff0c;实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构&#xff0c;服务器端使用Java Servlet处理请求&#xff0c;数据库采用MySQL存储信息&#xff0…...

【JVM面试篇】高频八股汇总——类加载和类加载器

目录 1. 讲一下类加载过程&#xff1f; 2. Java创建对象的过程&#xff1f; 3. 对象的生命周期&#xff1f; 4. 类加载器有哪些&#xff1f; 5. 双亲委派模型的作用&#xff08;好处&#xff09;&#xff1f; 6. 讲一下类的加载和双亲委派原则&#xff1f; 7. 双亲委派模…...

CRMEB 中 PHP 短信扩展开发:涵盖一号通、阿里云、腾讯云、创蓝

目前已有一号通短信、阿里云短信、腾讯云短信扩展 扩展入口文件 文件目录 crmeb\services\sms\Sms.php 默认驱动类型为&#xff1a;一号通 namespace crmeb\services\sms;use crmeb\basic\BaseManager; use crmeb\services\AccessTokenServeService; use crmeb\services\sms\…...

Go语言多线程问题

打印零与奇偶数&#xff08;leetcode 1116&#xff09; 方法1&#xff1a;使用互斥锁和条件变量 package mainimport ("fmt""sync" )type ZeroEvenOdd struct {n intzeroMutex sync.MutexevenMutex sync.MutexoddMutex sync.Mutexcurrent int…...