题目名称:查找整数

题目描述

给定一个非降序的整数数组,数组中包含重复数字(重复数字很多) ,给定任意整数,对数组进行二分查找,返回数组正确的位置,给出函数实现。 a. 连续相同的数字,返回最后一个匹配的位置 b. 如果数字不存在返回 -1。(测试用例仅做参考,我们会根据代码质量进行评分)

输入描述:

第一行给定数组长度n,目标值tar。(1<=n,tar<=10000) 第二行给出n个整数a.(1<=a<=10000)

输出描述:

按题目描述输出。

示例 

示例1

输入7 4
1 2 2 3 4 4 10复制

输出5

class Solution:
    def __init__(self) -> None:
        pass

    def solution(self):
        lis = input().strip().split(' ')
        num = input().strip().split(' ')
        n = int(lis[0])
        tar = int(lis[1])
        num = [int(i) for i in num]
        k = 0
        if num.count(tar) == 0:
            return(-1)
        if num.count(tar) != 0:
            for i in num[::-1]:
                k += 1
                if i == tar:
                    return (n - k)

if __name__ == "__main__":
    s = Solution()
    print(s.solution())

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 题目要求我们编写程序,找出给定n本书中价格最高和最低的书的名称和价格。输入格式为首先输入一个正整数n,表示有n本书,然后依次输入每本书的名称和价格。 我们可以先定义两个变量,一个用来存储最高价格的书的名称和价格,一个用来存储最低价格的书的名称和价格。然后依次读入每本书的信息,如果当前书的价格比最高价格还高,就更新最高价格的书的信息;如果当前书的价格比最低价格还低,就更新最低价格的书的信息。最后输出最高价格和最低价格的书的信息即可。 具体实现可以参考以下代码: ```python n = int(input()) # 输入n max_book = ['', ] # 存储最高价格的书的信息 min_book = ['', float('inf')] # 存储最低价格的书的信息 for i in range(n): name = input() # 读入书名 price = float(input()) # 读入价格 if price > max_book[1]: # 如果当前书的价格比最高价格还高 max_book = [name, price] # 更新最高价格的书的信息 if price < min_book[1]: # 如果当前书的价格比最低价格还低 min_book = [name, price] # 更新最低价格的书的信息 # 输出最高价格和最低价格的书的信息 print(max_book[], max_book[1]) print(min_book[], min_book[1]) ``` 希望能对你有所帮助! ### 回答2: 题目要求我们编写一个程序,查找并输出给定n本书中定价最高和最低的书的名称和价格。因此,我们需要实现以下步骤进行解题: 1. 输入n本书的信息。 题目给出n的取值范围在1~10之间,因此我们可以通过输入一个n来确定需要输入的书的数量。通过输入的方式,读入每一本书的名称和价格。其中,书名为字符串类型,长度不会超过30,因此我们可以通过读入一行字符串的方式来获取每一本书的名称。价格为正实数类型,因此我们也可以通过读入一行字符串的方式来获取每一本书的价格。 2. 查找定价最高和最低的书。 我们需要在给定的n本书中查找定价最高和最低的书,因此需要进行比较。我们可以通过定义两个变量max_price和min_price来分别表示当前定价最高的书的价格和当前定价最低的书的价格。初始值我们可以设置为当前读入的第一本书的价格。随后,在输入每一本书的价格时,逐一比较每本书的价格与max_price和min_price的大小关系,如果当前价格大于max_price,则将max_price更新为当前价格,并记录当前书名;如果当前价格小于min_price,则将min_price更新为当前价格,并记录当前书名。 3. 输出定价最高和最低的书的名称和价格。 通过以上的比较,我们已经找到了给定n本书中定价最高和最低的书,现在我们需要将其名称和价格通过输出的方式呈现出来。我们可以定义两个字符串变量max_name和min_name来分别记录定价最高和最低的书的名称。将其与相应的价格一并输出,即可完成题目要求。 综上,本题的解题思路主要包括以下几个部分:读入n本书的信息、查找定价最高和最低的书以及输出结果。在代码的实现中,需要注意字符串与实数类型的读入方式。 ### 回答3: 题目要求在给定n本书的名称和定价中,找到价格最高和最低的书的名称和定价。我们可以先读入n,然后循环读入每本书的名称和定价,同时记录价格最高和最低的书的名称和定价。 在记录价格最高和最低的书的时候,我们可以定义两个变量分别保存目前为止找到的最高和最低价格,同时在循环中比较每本书的价格,若其价格为当前找到的最高或最低价格,则更新记录。 最后输出定价最高和最低的书的名称和价格即可。 以下是示例代码实现: ```python n = int(input()) # 输入n max_price = 0 # 初始化最高价格为0 min_price = float('inf') # 初始化最低价格为正无穷 for i in range(n): name = input() # 读入书名 price = float(input()) # 读入价格 if price > max_price: # 若当前价格比最高价格高 max_name = name # 更新最高价格的书名和价格 max_price = price if price < min_price: # 若当前价格比最低价格低 min_name = name # 更新最低价格的书名和价格 min_price = price # 输出结果 print(max_name, max_price) print(min_name, min_price) ``` 注意,以上代码实现中的变量名和注释都是为了方便理解而起,并非强制要求使用相同的。在实际开发中,合理的变量命名和注释可以让代码更直观易懂。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值