鱼C论坛

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

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

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

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

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

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

LeetCode.jpg
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-4-27 08:42:56 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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


class Solution {
public:
    int findMin(vector<int>& nums) {
        for(int idx=1;idx<nums.size();idx++){
            if(nums[idx]<nums[idx-1]){
                return nums[idx];
            }
        }
        return nums[0];
    }
};
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-27 08:46:22 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-27 08:49:37 | 显示全部楼层
int findMin(int* nums, int numsSize){
    int last=*nums++;
    while(--numsSize){
        if(*nums<last){
            return *nums;
        }
        nums++;
    }
    return last;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

肯定过了啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-27 08:50:48 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-27 08:51:57 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

    }
};
2.参考题解二分法做的
class Solution {
public:
    int findMin(vector<int>& nums) {
        int left = 0, right = nums.size()-1;
        while(left <= right){
            if(nums[right] >= nums[left])return nums[left];
            int mid = left + (right - left) /2;
            if(nums[mid] >= nums[left]){
                left = mid + 1;
            }
            else if(nums[mid] < nums[left]){
                right = mid;
            }
        }
        return -1;

    }
};


两个方法提交结果差不多
捕获.PNG
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

ohhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhh
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-26 22:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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