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

ios移动网站开发详解拿别的公司名字做网站

ios移动网站开发详解,拿别的公司名字做网站,企业邮箱在哪里看,网络营销师报名官网题目一:两数之和 给出一个整型数组 numbers 和一个目标值 target,请在数组中找出两个加起来等于目标值的数的下标,返回的下标按升序排列。 (注:返回的数组下标从1开始算起,保证target一定可以由数组里面2…

题目一:两数之和

给出一个整型数组 numbers 和一个目标值 target,请在数组中找出两个加起来等于目标值的数的下标,返回的下标按升序排列。

(注:返回的数组下标从1开始算起,保证target一定可以由数组里面2个数字相加得到)

方法一,双层for遍历:

不过,这种方法在牛客网上执行的时候报超时错误

import java.util.*;
public class Solution {/*** * @param numbers int整型一维数组 * @param target int整型 * @return int整型一维数组*/public int[] twoSum (int[] numbers, int target) {// write code hereint n = numbers.length;int[] res = {-1, -1};//遍历数组for (int i = 0; i < n; ++i) {for (int j = i + 1; j < n; ++j) {//判断相加值是否为targetif (numbers[i] + numbers[j] == target) {res[0] = i+1;res[1] = j+1;//返回值return res;}}}return res;}
}

复杂度分析:

  • 时间复杂度:O(n^2) 遍历两次数组
  • 空间复杂度:O(1) 未申请额外空间

 方法二,hash表

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param numbers int整型一维数组* @param target int整型* @return int整型一维数组*/public int[] twoSum (int[] numbers, int target) {HashMap<Integer, Integer> map = new HashMap<>();//遍历数组for (int i = 0; i < numbers.length; i++) {if (map.containsKey(target - numbers[i])) {// 这里题目要求下标在数组中升序排列,这里这样放直接就满足了题意,因为数据A肯定先放入map,后面containsKey判断得出的数据B的下标i肯定大于数据A下标return new int[] {map.get(target - numbers[i]) + 1, i + 1};} else {map.put(numbers[i], i);}}throw new IllegalArgumentException("No solution");}
}

复杂度分析:

  • 时间复杂度:O(n) 一次遍历hash索引查找时间复杂度为O(1)
  • 空间复杂度:O(n) 申请了n大小的map空间

题目二:最接近的三数之和 

描述

给定一个数组 nums 和一个目标值 target ,请问从 nums 中选出三个数,使其之和尽量接近目标数,即三数之和与目标数只差绝对值尽可能小。

返回满足题面要求的三数之和。

数据范围:数组长度满足3≤n≤300  ,数组中的值满足 ∣nums[i]∣≤1000  ,目标值满足∣target∣≤10^4 ,可以保证只有一个结果。

 方法一,暴力三层循环

循环累加,计算三个数之和与目标值target差值绝对值最小

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param nums int整型一维数组 * @param target int整型 * @return int整型*/public int ClosestSum (int[] nums, int target) {// write code hereint sum_min = Integer.MAX_VALUE;int result=0;for(int i=0;i<nums.length-2;i++){for(int j=i+1;j<nums.length-1;j++){for(int k=j+1;k<nums.length;k++){int sum=nums[i]+nums[j]+nums[k];if(Math.abs(sum-target)<sum_min){sum_min=Math.abs(sum-target);result=sum;}}}}return result;}
}

方法二,先排序再循环 

数组在没有排序之前不容易实现某种算法,排序完之后,在固定第一个数字的情况下,通过与之后数据中头尾数据相加得sum,与target求差,循环比对差距大小。同时头尾数据会根据与target大小做调整,当sum>target时,尾数据下标-1,当sum<target时,头数据下标+1,sum=target,则可以直接返回。

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param nums int整型一维数组* @param target int整型* @return int整型*/public int ClosestSum (int[] nums, int target) {// write code here// 排序Arrays.sort(nums);// 记录结果int res = nums[0] + nums[1] + nums[2];for (int i = 0; i < nums.length - 2; i++) {// 头尾数据下标int start = i + 1;int end = nums.length - 1;while (start < end) {int sum = nums[i] + nums[start] + nums[end];//每次头尾数据变更之后,比对差值大小if (Math.abs(sum - target) < Math.abs(res - target)) {res = sum;}if (sum > target) {end--;} else if (sum < target) {start++;} else {return sum;}}}return res;}
}

http://www.15wanjia.com/news/170129.html

相关文章:

  • 常德做网站报价太原建站建设
  • 杭州网站优化推荐温州专业微网站制作多少钱
  • 郑州高端网站模板wordpress 字库
  • 网站后台登录不进去松江区网站开发
  • 注册网站会员违法网站建设需要的费用
  • 南宁网站推广手段做软件项目的网站
  • 余杭区建设规划局网站开发公司标牌制作费计入什么科目
  • 临夏城乡建设局网站怎样做企业宣传推广
  • 网站关键词热度苏州十大软件公司招聘
  • 做网站租服务器需要多少钱自学网站开发难吗
  • 网站手机端设计四川刚刚发布的最新新闻
  • 小说网站建立微信网站制作系统
  • 网站为什么开发app深圳建设网站制作
  • 网站开发设计公司块位有没有专门做建材的网站
  • 网站建设与管理代码个人做网站要买什么域名
  • 网站域名转出网站弹屏广告怎么做的
  • 网站开发什么叫前端后端制作视频模板
  • 手机wap网站模板WordPress信息收集
  • 备案网站的黑名单深圳网页设计推广渠道
  • 公司做网站需要准备什么给wordpress添加表单
  • 中药材网站开发中国网络科技公司排名
  • 新建网站二级网页怎么做电子商城网站建设
  • 泰州建设局网站安监站通报容桂企业网站建设
  • 手机网站开发流程图交易平台
  • 你们需要网站建设网页版快手
  • 如何管理网站域名图片模板制作app
  • 西安网站 技术支持牛商网同学录网站开发实现基本要求
  • 成都网站建设哪家比较好免费推广的平台都有哪些
  • 电子商务网站建设(论文网上自建网站开店
  • 模板展示网站源码o2o电商平台有哪些?