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

外文网站做t检验分析舆情网站入口

外文网站做t检验分析,舆情网站入口,合肥建站免费模板,wordpress响应式网站模板文章目录 零、原题链接一、题目描述二、测试用例三、解题思路3.1 排序双指针3.1 散列 四、参考代码4.1 排序双指针4.2 散列 零、原题链接 NC61 两数之和 一、题目描述 二、测试用例 三、解题思路 3.1 排序双指针 基本思路:   先对序列进行排序,然后…

文章目录

  • 零、原题链接
  • 一、题目描述
  • 二、测试用例
  • 三、解题思路
    • 3.1 排序+双指针
    • 3.1 散列
  • 四、参考代码
    • 4.1 排序+双指针
    • 4.2 散列

零、原题链接


NC61 两数之和

一、题目描述

在这里插入图片描述

二、测试用例

在这里插入图片描述

三、解题思路

3.1 排序+双指针

  1. 基本思路:
      先对序列进行排序,然后使用双指针从头和尾进行操作。
  2. 具体思路:
    • 建立值到下标的映射;
    • 序列从小到大排序;
    • 定义双指针 ij ,指针 i 表示头,指针 j 表示尾,迭代直到 i>j
      • 如果两个指针的值相加等于目标,则返回对应值在序列的位置;
      • 如果两个指针的值相加大于目标,则 j-- ;【想办法减小两个值的和】
      • 如果两个指针的值相加等于目标,则 i++ ;【想办法增加两个值的和】

3.1 散列

  1. 基本思路:
      每次遍历到一个元素,从遍历过的数中看看是否能找到目标减去该元素的值。
  2. 具体思路:
    • 遍历所有元素
    • 如果可以在 map 中找到目标值减去该元素的值,则返回两个元素的下标;
    • 如果没有找到,则将该元素按照 {元素值,下标} 的方式插入到 map 中;

四、参考代码

4.1 排序+双指针

时间复杂度: O ( n l o g n ) \Omicron(nlog\;n) O(nlogn)
空间复杂度: O ( n ) \Omicron(n) O(n)

#include <functional>
#include <numeric>
#include <utility>
#include <vector>
class Solution {public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param numbers int整型vector* @param target int整型* @return int整型vector*/vector<int> twoSum(vector<int>& numbers, int target) {int n = numbers.size();vector<pair<int, int>> numtoi(n);vector<int> ans;for (int i = 0; i < n; i++) {numtoi[i] = make_pair(numbers[i], i + 1);}sort(numtoi.begin(), numtoi.end(), [&](const pair<int, int>& x,const pair<int, int>& y) {return x.first < y.first;});int i = 0, j = n - 1;while (i < j) {if (numtoi[i].first + numtoi[j].first == target) {ans.emplace_back(numtoi[i].second);ans.emplace_back(numtoi[j].second);if (ans[0] > ans[1])swap(ans[0], ans[1]);break;} else if (numtoi[i].first + numtoi[j].first < target) {i++;} else {j--;}}return ans;}
};

4.2 散列

时间复杂度: O ( n ) \Omicron(n) O(n)
空间复杂度: O ( n ) \Omicron(n) O(n)

#include <functional>
#include <numeric>
#include <unordered_map>
#include <utility>
#include <vector>
class Solution {public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param numbers int整型vector* @param target int整型* @return int整型vector*/vector<int> twoSum(vector<int>& numbers, int target) {unordered_map<int, int> m;for (int i = 0; i < numbers.size(); i++) {int rest = target - numbers[i];if (m.count(rest) == 1) {return {m[rest] + 1, i + 1};} else {m.emplace(numbers[i], i);}}return {};}
};
http://www.dtcms.com/wzjs/318445.html

相关文章:

  • 珠海网站建设网上推销产品的软件
  • 外地公司做的网站能备案优化大师win10能用吗
  • 网站建设哪些好大连百度关键词优化
  • wordpress统计代码班级优化大师官方免费下载
  • 张家口企业网站建设小广告网页
  • 深圳模板网站建设网络营销的内容
  • wordpress做社交网站吗陕西seo主管
  • 网站采集被降权seo推广主要做什么
  • wordpress网站不稳定seo优化工作怎么样
  • 吴中区建设局网站图片外链在线生成网址
  • 山东淄博网站建设公司win7优化大师
  • 江西网站开发公司百度官网认证
  • 网站申请名称竞价托管公司
  • 如何免费建立公司网站东莞网站推广的公司
  • 怎么才能建设免费网站青岛seo推广专员
  • 个人微信号做网站行吗郑州官网网站推广优化公司
  • 深圳建模板网站什么是市场营销
  • 建材公司网站建设方案网站营销策划公司
  • 网站排名优化策划网络服务平台
  • 电子商务网站建设感想百度云搜索引擎官网入口
  • seo快速排名关键词如何结合搜索检索与seo推广
  • Wordpress页面怎么使用杭州哪家seo公司好
  • 新加坡vpsseo门户网站建设方案
  • 我要做个网站该怎么做个人网站制作多少钱
  • 有没有做婚车的网站百度推广怎么推广
  • 公司都是自己制作网站如何写软文
  • 做国外进口衣服的网站好安徽疫情最新情况
  • 网页版微信会在电脑上留下记录吗南京市网站seo整站优化
  • 谷歌浏览器怎么删除2345网址导航青岛seo全网营销
  • 一家只做直购的网站上海做seo的公司