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

做电器的集团网站海外推广营销平台

做电器的集团网站,海外推广营销平台,wordpress5.1.1编辑器还原,自己做的网站如何调入dedeleetcode 150道题 计划花两个月时候刷完之未完成后转,今天(第1天)完成了4道(101-104)150: 101.(215. 数组中的第K个最大元素) 题目描述: 给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。 请…

leetcode 150道题 计划花两个月时候刷完之未完成后转,今天(第1天)完成了4道(101-104)150:

101.(215. 数组中的第K个最大元素) 题目描述:

给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。
请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。
你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。

第一版(这个题看了好几天。。复习了快排的写法,也算有收获,最后还是看了解题)

class Solution {Random random=new Random();public int findKthLargest(int[] nums, int k) {return quickSort(nums,0,nums.length-1,nums.length-k);}public int quickSort(int[] nums, int left,int right,int k){if(left>=right){return nums[k];}int randomIndex=left+random.nextInt(right-left+1);swap(nums,left,randomIndex);int middleNum=nums[left];int leftTemp=left+1;int rightTemp=right;while(leftTemp<=rightTemp){while(leftTemp<=rightTemp&&nums[rightTemp]>middleNum){rightTemp--;}while(leftTemp<=rightTemp&&nums[leftTemp]<middleNum){leftTemp++;}if(leftTemp>=rightTemp){break;}swap(nums,leftTemp,rightTemp);leftTemp++;rightTemp--;}swap(nums,left,rightTemp);if(k==rightTemp){return nums[rightTemp];}else if(k>rightTemp){return quickSort(nums,rightTemp+1,right,k);}else{return quickSort(nums,left,rightTemp-1,k);}}public void swap(int[] nums, int left,int right){int temp=nums[left];nums[left]=nums[right];nums[right]=temp;}
}

第二版(用了java 自带的堆集合,大堆根)

class Solution {public int findKthLargest(int[] nums, int k) {int len=nums.length;PriorityQueue<Integer> priorityQueue=new PriorityQueue<Integer>(len,(o1,o2)->o2.compareTo(o1));for(int num:nums){priorityQueue.offer(num);}for(int i=0;i<k-1;i++){priorityQueue.poll();}return priorityQueue.peek();}
}

102.(373. 查找和最小的 K 对数字)题目描述:

给定两个以 非递减顺序排列 的整数数组 nums1 和 nums2 , 以及一个整数 k 。
定义一对值 (u,v),其中第一个元素来自 nums1,第二个元素来自 nums2 。
请找到和最小的 k 个数对 (u1,v1),  (u2,v2)  ...  (uk,vk)

第一版(我一上来就是全部结果拿到然后排序返回前K个,然后报超时,解题的去重不是很好的理解的。意思就是先将开头的放进去,然后下面取下一个要出现的组合时候只需要向右找就行这样就不会重复了)

class Solution {public List<List<Integer>> kSmallestPairs(int[] nums1, int[] nums2, int k) {List<List<Integer>> res=new ArrayList();PriorityQueue<int[]> priority=new PriorityQueue<int[]>(k,(o1,o2)->{return nums1[o1[0]]+nums2[o1[1]]-nums1[o2[0]]-nums2[o2[1]];});int m=nums1.length;int n=nums2.length;for(int i=0;i<Math.min(m,k);i++){priority.offer(new int[]{i,0});}while(k-->0&&!priority.isEmpty()){int[] temp=priority.poll();List<Integer> list=new ArrayList();list.add(nums1[temp[0]]);list.add(nums2[temp[1]]);res.add(list);if(temp[1]+1<n){priority.offer(new int[]{temp[0],temp[1]+1});}}return res;}
}

103.(67. 二进制求和)题目描述:

给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。
示例 :
输入:a = "11", b = "1"
输出:"100"

第一版(用java自带的api先转为整数相加然后再转为2进制会超长,所以只能慢慢算,我写的有点啰嗦。。)

class Solution {public String addBinary(String a, String b) {StringBuilder sb=new StringBuilder();int lenA=a.length();int lenB=b.length();int indexA=lenA-1;int indexB=lenB-1;boolean flag=false;while(indexA>=0&&indexB>=0){if(flag){if(a.charAt(indexA)=='1'&&b.charAt(indexB)=='1'){sb.insert(0,'1');}else if(a.charAt(indexA)=='1'||b.charAt(indexB)=='1'){sb.insert(0,'0');}else{sb.insert(0,'1');flag=false;}}else{if(a.charAt(indexA)=='1'&&b.charAt(indexB)=='1'){sb.insert(0,'0');flag=true;}else if(a.charAt(indexA)=='1'||b.charAt(indexB)=='1'){sb.insert(0,'1');}else{sb.insert(0,'0');}}indexA--;indexB--;}while(indexA>=0){if(flag){if(a.charAt(indexA)=='1'){sb.insert(0,'0');}else{sb.insert(0,'1');flag=false;}}else{if(a.charAt(indexA)=='1'){sb.insert(0,'1');}else{sb.insert(0,'0');}}indexA--;}while(indexB>=0){if(flag){if(b.charAt(indexB)=='1'){sb.insert(0,'0');}else{sb.insert(0,'1');flag=false;}}else{if(b.charAt(indexB)=='1'){sb.insert(0,'1');}else{sb.insert(0,'0');}}indexB--;}if(flag){sb.insert(0,'1');}return sb.toString();}
}

104.(190. 颠倒二进制位)题目描述:

颠倒给定的 32 位无符号整数的二进制位。

第一版(java 有自带的 api )

public class Solution {// you need treat n as an unsigned valuepublic int reverseBits(int n) {return Integer.reverse(n);}
}

第二版(位运算)

public class Solution {// you need treat n as an unsigned valuepublic int reverseBits(int n) {int num=0;for(int i=1;i<=32;i++){num<<=1;//先向左移动一位留出位置//取出 n 的最后一位int p=(n&1);num+=p;n>>=1;}return num; }
}

年过完了。。亲也相完了。。回归正常!!!

http://www.hrbkazy.com/news/6322.html

相关文章:

  • 百度怎么自己做网站吗学网络运营在哪里学比较好
  • 网站上的超链接怎么做最受欢迎的十大培训课程
  • 爱做网站网址宣传推广方案怎么写
  • 南昌专业做网站的病毒式营销的案例
  • 网站开发备案产品推广策划
  • 农业电商网站建设方案百度站长平台注册
  • 做网站图注意事项定制网站和模板建站
  • 羽贝网站建设网站优化seo
  • 北京门户网站制作公司网络广告策划流程有哪些?
  • 如何用rp做网站百度文库个人登录
  • 网站代码开发方式产品设计公司
  • 做浏览任务赚钱的网站产品推广策划书
  • 做网站的画布是多少关键词在线下载
  • 代办医疗网站域名备案天津网站快速排名提升
  • 建站吗官方网站线上营销方案
  • 泰州网站设计公司seo服务工程
  • 凡科建站网页版网络营销策划案例
  • 域名新闻网站营销网站建设的因素
  • 站群搭建百度推广登录入口下载
  • 网站建设服务器什么意思百度网站
  • 建设网站ppt营销最好的方法
  • 网站运营工作是干什么的石家庄网络推广平台
  • 做网站的必要条件网站排名优化制作
  • 做任务赚q红包的网站南宁在哪里推广网站
  • 网站建设 上海网cpa广告联盟平台
  • 北京营销型网站建设哪家好360优化大师官方免费下载
  • 委托网站开发所有权归属深圳全网推广效果如何
  • 坑人的网站链接怎么做常见的网络营销策略都有哪些
  • 中国企业网查询系统官网全国seo搜索排名优化公司
  • 网站开发与应用论文百度快照推广一年要多少钱