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

景德镇网站建设哪家好二维码图片生成器在线制作

景德镇网站建设哪家好,二维码图片生成器在线制作,做搜狗手机网站快速排,wordpress 4.7.5中文版454.四数相加II 四个数组分成两组进行for循环,先用HashMap存储所有第一组for循环出现的和的次数。再进行第二组for循环,每一次得出的和判断其负数是否在map的key中,如果存在,就加上这个value。 class Solution {public int four…

454.四数相加II

四个数组分成两组进行for循环,先用HashMap存储所有第一组for循环出现的和的次数。再进行第二组for循环,每一次得出的和判断其负数是否在map的key中,如果存在,就加上这个value。

class Solution {public int fourSumCount(int[] nums1, int[] nums2, int[] nums3, int[] nums4) {HashMap<Integer,Integer> map = new HashMap<Integer,Integer>();for(int num1:nums1){for(int num2:nums2){if(map.containsKey(num1+num2)){int a = map.get(num1+num2);map.put(num1+num2,++a);}else{map.put(num1+num2,1);}}}int total = 0;for(int num3:nums3){for(int num4:nums4){if(map.containsKey(-(num3+num4))){total += map.get(-(num3+num4));}}}return total;}
}

383. 赎金信

和有效的字母异位词那道题目类似

class Solution {public boolean canConstruct(String ransomNote, String magazine) {int[] record = new int[26];for(int i = 0;i < magazine.length();i++){record[magazine.charAt(i)-'a']++;}for(int i = 0;i < ransomNote.length();i++){record[ransomNote.charAt(i)-'a']--;}for(int r:record){if(r < 0) return false;}return true;}
}

15. 三数之和

真题思路就是用i遍历整个数组,每次遍历过程中定义一个left和一个right,计算nums[i]+nums[left]+nums[right],
1.如果sum大于0 right–
(因为nums[right–]<nums[right],所以nums[i]+nums[left]+nums[right–]<nums[i]+nums[left]+nums[right]);
2.如果sum小于0 left++
(因为nums[left++]>nums[left],所以nums[i]+nums[right]+nums[left++]>nums[i]+nums[left]+nums[right])

class Solution {public List<List<Integer>> threeSum(int[] nums) {List<List<Integer>> resList = new ArrayList<List<Integer>>();Arrays.sort(nums);if(nums[0] > 0 || nums[nums.length-1] < 0 || nums.length < 3) return resList;//nums的第一个大于0或者最后一个小于0或者数组个数小于3,都返回空集合for(int i = 0;i<nums.length;i++){if(i != 0 && nums[i] == nums[i-1]) continue;/*比如数组[-1,-1,0,1,2],nums[0]和nums[1]都为-1,对i=0的情况找出了[-1,-1,2]和为0的情况之后,*再讨论i=1的情况又会得出一个[-1,-1,2]的答案,会有重复。但是不能nums[i] == nums[i+1]这样向后对比,*因为nums[0]=nums[1],直接跳过i=0,就忽略了[-1,-1,2]这种情况。*/int left = i+1;int right = nums.length-1;while(left < right){int sum = nums[i]+nums[left]+nums[right];if(sum == 0){resList.add(Arrays.asList(nums[i],nums[left],nums[right]));left++;right--;while(left < right && nums[left] == nums[left-1]) left++;//比如nums=[-2,-1,-1,0,5],i=0,left=1,right=4的情况判断完之后,就不必再对left=1的情况再判断一遍直接跳到left=2即可,这样减少了时间消耗//但也不可忽视left要小于right,比如nums=[-3,-1,-1,-1],left会一直++到超出数组索引范围,所以要有left < right的限制while(left < right && right != nums.length-1 && nums[right] == nums[right+1]) right--;//同理}else if(sum > 0){right--;}else if(sum < 0){left++;}else{break;}} }return resList;}}

18. 四数之和

class Solution {public List<List<Integer>> fourSum(int[] nums, int target) {Arrays.sort(nums);List<List<Integer>> listRes = new ArrayList<List<Integer>>();for(int i = 0;i < nums.length-3;i++){if(i != 0 && nums[i] == nums[i-1]) continue;//去重for(int j = i+1;j<nums.length-2;j++){if(j != i+1 && nums[j] == nums[j-1]) continue;//去重int left = j+1;int right = nums.length-1;while(left < right){long sum = (long) nums[i] + (long)nums[j] + (long)nums[left] + (long)nums[right];if(sum==target){ArrayList<Integer> list = new ArrayList<Integer>();listRes.add(Arrays.asList(nums[i],nums[j],nums[left],nums[right]));left++;right--;while(left < right && nums[left] == nums[left-1]) left++;//去重while(left < right && right != nums.length - 1 && nums[right] == nums[right+1]) //去重right--;}else if(sum>target){right--;}else{left++;}}}}return listRes;}
}
http://www.yayakq.cn/news/674165/

相关文章:

  • 网站开发电子书欧洲c2c平台
  • 好的摄影网站移动宽带可以在网上续费吗
  • 网站接单园区网站建设调研报告
  • 下载类网站 前置备案临安市建设局网站
  • 旅游建设网站目的及功能定位珠海市外贸网站建设公司
  • 网站建站网站网站维护给人做违法网站规避
  • 网站项目需求说明书响应式网站的宽度
  • 旅游网站设计的目的与意义网站会员系统wordpress
  • 政协网站建设天津网站开发建设公司
  • 深圳建设集团网站官网响应式网站模板分享
  • 儿童玩具网站建设实训报告跳转链接
  • 做彩票网站推广网站的导航栏
  • 怎么开网店详细步骤教程权威网站优化价格
  • 做算法的网站做的网站电脑上跟手机上不一样
  • 韩国源代码交易网站深圳如何建立公司自己网站
  • 怎么网站做二维码云服务器和网站空间
  • 怎么查网站死链wordpress模板 微信
  • 三水建设网站php微网站开发
  • c 网站开发 书起飞页怎么做网站
  • 公司建设网站需要什么资质母婴用品网站建设
  • 对门户网站建设情况的报告暴雪游戏排行榜前十名
  • 腾讯云服务器用什么做网站网站建设宣传方案
  • 滴滴注册网站做教育培训应该注册什么公司
  • 与做网站的人怎么谈判高中课程免费教学网站
  • 云主机 网站指南百度网页链接
  • 网站免费推广的方法长沙房产网最新楼盘地图
  • 最容易做的门户网站湘潭做网站价格问下磐石网络
  • 开网站做网站邵阳营销型网站建设
  • 湘潭网站建设 r磐石网络移动端网站宽度做多大
  • 小企业网站建设哪找网站建设完成