皖icp备 网站建设,公司起名字大全免费好听必过的,网站添加wordpress,WordPress上传ssl证书作者#xff1a;小卢 专栏#xff1a;《Leetcode》 喜欢的话#xff1a;世间因为少年的挺身而出#xff0c;而更加瑰丽。 ——《人民日报》 目录 33. 搜索旋转排序数组 1290. 二进制链表转整数 33. 搜索旋转排序数组
33. 搜索旋转排序… 作者小卢 专栏《Leetcode》 喜欢的话世间因为少年的挺身而出而更加瑰丽。 ——《人民日报》 目录 33. 搜索旋转排序数组 1290. 二进制链表转整数 33. 搜索旋转排序数组
33. 搜索旋转排序数组https://leetcode.cn/problems/search-in-rotated-sorted-array/ 题目描述
整数数组 nums 按升序排列数组中的值 互不相同 。
在传递给函数之前nums 在预先未知的某个下标 k0 k nums.length上进行了 旋转使数组变为 [nums[k], nums[k1], ..., nums[n-1], nums[0], nums[1], ..., nums[k-1]]下标 从 0 开始 计数。例如 [0,1,2,4,5,6,7] 在下标 3 处经旋转后可能变为 [4,5,6,7,0,1,2] 。
给你 旋转后 的数组 nums 和一个整数 target 如果 nums 中存在这个目标值 target 则返回它的下标否则返回 -1 。
你必须设计一个时间复杂度为 O(log n) 的算法解决此问题。
注意logN的算法一般就是二分
示例 思路
显然本题logN的算法我们需要二分来解决
我们可以将数组二分成两个不同的数组一个数组是有序的一个数组是无序的。
我们先判断target是否在有序数组里面如果有继续二分如果没有那我们来二分不是有序的数组。
代码
int search(int* nums, int numsSize, int target){int left0;int rightnumsSize-1;int mid0;if(leftrightnums[left]target)return left;//防止leftright1的情况while(leftright){if(nums[left]target)return left;if(nums[right]target)return right;mid(leftright)/2;if(nums[mid]target) return mid;if(nums[left]nums[mid]){//left-mid-1有序if(targetnums[left]targetnums[mid])rightmid-1;else{//在不是有序的mid1-rightleftmid1;}}else{//mid1-right有序if(targetnums[mid]targetnums[right])leftmid1;elserightmid-1;}}
return -1;
} 1290. 二进制链表转整数
1290. 二进制链表转整数https://leetcode.cn/problems/convert-binary-number-in-a-linked-list-to-integer/ 题目描述
给你一个单链表的引用结点 head。链表中每个结点的值不是 0 就是 1。已知此链表是一个整数数字的二进制表示形式。
请你返回该链表所表示数字的 十进制值 。
示例 代码
/*** Definition for singly-linked list.* struct ListNode {* int val;* struct ListNode *next;* };*/int getDecimalValue(struct ListNode* head){int arr[32];int num0;struct ListNode*curhead;while(cur){arr[num]cur-val;curcur-next;}int n0;int i0;while(num--){n(int)pow(2,num)*arr[i];}return n;
}