鱼C论坛

 找回密码
 立即注册
查看: 1776|回复: 9

[技术交流] 16.寻找旋转排序数组中的最小值

[复制链接]
发表于 2020-4-27 08:27:53 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 _2_ 于 2020-4-28 14:53 编辑
  1. class Solution:
  2.     def findMin(self, nums: List[int]) -> int:
  3.         """
  4.         153.寻找旋转排序数组中的最小值
  5.         https://leetcode-cn.com/problems/find-minimum-in-rotated-sorted-array/
  6.         """
  7.         return min(nums)
复制代码


LeetCode.jpg
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-4-27 08:42:56 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-27 08:44:57 | 显示全部楼层
  1. const static int _=[](){
  2.     ios::sync_with_stdio(0);
  3.     cin.tie(0);
  4.     cout.tie(0);
  5.     return 0;
  6. }();


  7. class Solution {
  8. public:
  9.     int findMin(vector<int>& nums) {
  10.         for(int idx=1;idx<nums.size();idx++){
  11.             if(nums[idx]<nums[idx-1]){
  12.                 return nums[idx];
  13.             }
  14.         }
  15.         return nums[0];
  16.     }
  17. };
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-27 08:46:22 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-27 08:49:37 | 显示全部楼层
  1. int findMin(int* nums, int numsSize){
  2.     int last=*nums++;
  3.     while(--numsSize){
  4.         if(*nums<last){
  5.             return *nums;
  6.         }
  7.         nums++;
  8.     }
  9.     return last;
  10. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-27 08:50:16 | 显示全部楼层
_2_ 发表于 2020-4-27 08:46
通过了吗???

肯定过了啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-27 08:50:48 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-27 08:51:57 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-27 10:44:58 | 显示全部楼层
C++
1.自己做的
  1. class Solution {
  2. public:
  3.     int findMin(vector<int>& nums) {
  4.         int len = nums.size();
  5.         if(len == 1) return nums[0];
  6.         for(int i = 1; i < len; i++){
  7.             if(nums[i] < nums[i-1]) return nums[i];
  8.         }
  9.         return nums[0];

  10.     }
  11. };
复制代码

2.参考题解二分法做的
  1. class Solution {
  2. public:
  3.     int findMin(vector<int>& nums) {
  4.         int left = 0, right = nums.size()-1;
  5.         while(left <= right){
  6.             if(nums[right] >= nums[left])return nums[left];
  7.             int mid = left + (right - left) /2;
  8.             if(nums[mid] >= nums[left]){
  9.                 left = mid + 1;
  10.             }
  11.             else if(nums[mid] < nums[left]){
  12.                 right = mid;
  13.             }
  14.         }
  15.         return -1;

  16.     }
  17. };
复制代码



两个方法提交结果差不多
捕获.PNG
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-27 10:52:41 | 显示全部楼层

ohhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhh
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-18 05:11

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表