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

网站开发技术总结报告惠州住房和建设局网站

网站开发技术总结报告,惠州住房和建设局网站,鄂州网吧暂停营业,久久建筑网怎么不好用1. 两数之和 给定一个整数数组 nums 和一个整数目标值 target#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是#xff0c;数组中同一个元素在答案里不能重复出现。 你可以按…1. 两数之和 给定一个整数数组 nums 和一个整数目标值 target请你在该数组中找出 和为目标值 target 的那 两个 整数并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是数组中同一个元素在答案里不能重复出现。 你可以按任意顺序返回答案。 示例 1 输入nums [2,7,11,15], target 9 输出[0,1] 解释因为 nums[0] nums[1] 9 返回 [0, 1] 。 示例 2 输入nums [3,2,4], target 6 输出[1,2] 示例 3 输入nums [3,3], target 6 输出[0,1] 提示 2 nums.length 104-109 nums[i] 109-109 target 109只会存在一个有效答案 进阶 你可以想出一个时间复杂度小于 O(n2) 的算法吗 解题方法—C语言 /*** Note: The returned array must be malloced, assume caller calls free().*/ //最蠢的办法暴力输出 //根据提醒的target是目标数值一个数组numsnumsSize是数组的大小returnSize是如果有目标数则返回2如果没有则返回0 int* twoSum(int* nums, int numsSize, int target, int* returnSize) {int* ret (int*)malloc(sizeof(int)*2); //创立空间用于存储目标数值for(int i 0;inumsSize-1;i)for(int j i1;jnumsSize;j)if(nums[i]nums[j]target){ret[0] i;ret[1] j;*returnSize 2;return ret; }*returnSize 0;return NULL;}解题方法—cpp class Solution { public:vectorint twoSum(vectorint nums, int target) {int len nums.size();//数组的大小for(int i 0;i len-1;i)for(int j i1;jlen;j)if(nums[i]nums[j]target){return {i,j}; //返回相应的数值}return {};//返回空} };非暴力的解法 哈希表 C语言的并不好理解涉及的东西有点多 //被这个结构吓了一跳c没有相应的函数还是太繁琐。struct hashTable {int key;int val;UT_hash_handle hh; //哈希表的句柄 };struct hashTable* hashtable; //哈希表的指针用于存储键对值// 在哈希表中查找键为 ikey 的元素并返回指向该元素的指针 struct hashTable* find(int ikey) {struct hashTable* tmp;HASH_FIND_INT(hashtable, ikey, tmp);// 使用宏 HASH_FIND_INT 在哈希表中查找元素return tmp; } // 向哈希表中插入键值对 (ikey, ival) void insert(int ikey, int ival) {struct hashTable* it find(ikey);// 查找键为 ikey 的元素if (it NULL) {struct hashTable* tmp malloc(sizeof(struct hashTable));// 如果不存在创建一个新节点tmp-key ikey, tmp-val ival;// 设置键值对的值HASH_ADD_INT(hashtable, key, tmp); // 使用宏 HASH_ADD_INT 向哈希表中添加元素} else {it-val ival; // 如果存在更新值} } // 在数组 nums 中找到两个数之和等于 target 的索引并返回这两个索引构成的数组 int* twoSum(int* nums, int numsSize, int target, int* returnSize) {hashtable NULL;// 初始化哈希表for (int i 0; i numsSize; i) {struct hashTable* it find(target - nums[i]);// 在哈希表中查找与当前元素相加等于 target 的元素if (it ! NULL) {// 如果找到了int* ret malloc(sizeof(int) * 2);// 创建一个数组用于存储结果ret[0] it-val, ret[1] i;// 存储找到的两个索引*returnSize 2; // 设置返回数组的大小return ret;// 返回结果数组}insert(nums[i], i);}*returnSize 0; // 如果找不到返回空数组return NULL; } cpp实现貌似眉清目秀 // 使用哈希表存储已经遍历过的数字及其索引以便快速查找目标值与当前值的差值是否在数组中存在 class Solution { public:vectorint twoSum(vectorint nums, int target) {unordered_mapint, int hashtable; // 哈希表键为数组元素值值为数组元素索引for (int i 0; i nums.size(); i) { // 遍历数组auto it hashtable.find(target - nums[i]); // 在哈希表中查找目标值与当前值的差值是否存在if (it ! hashtable.end()) { // 如果差值存在return {it-second, i}; // 返回差值对应的索引和当前值的索引}hashtable[nums[i]] i; // 将当前值及其索引存入哈希表}return {}; // 如果不存在符合条件的索引对返回空数组} }; 复杂度分析 时间复杂度O(N)O(N)O(N)其中 N 是数组中的元素数量。对于每一个元素 x我们可以 O(1)地寻找 target - x。 空间复杂度O(N)其中 N是数组中的元素数量。主要为哈希表的开销。
http://www.sczhlp.com/news/184541/

相关文章:

  • 提高网站建设水平意见方案wordpress 游客
  • 网站有订单了有声音提醒怎么做百度文库小程序入口
  • 墨刀做网站上下滑动的交互建设网站需要什么技术
  • 网站正能量免费软件番禺做哪些做网站的
  • 做课件用这15大网站wordpress如何上传超过2m
  • 潍城区建设局网站展馆设计方案ppt
  • 网站开发介绍人拿多少钱wordpress gzip压缩
  • 优化网站链接的方法世界500强企业排名2023
  • IDEA创建maven项目的不同模板的含义
  • 示波器BLDC需要知道的知识
  • 基于Java+Springboot+Vue开发的体育场馆预约管理系统源码+运行步骤
  • Linux 终端查看最消耗 CPU 内存的进程
  • 专业手机网站怎么做wordpress增加会员中心
  • 织梦做网站简单吗网上怎么卖东西流程
  • 服务器里怎么建设网站wordpress产品属性搭配
  • 地方旅游网站模板会员管理系统c语言
  • unsplash素材网站享设计官网
  • 专门做校招的网站网上推广渠道有哪些
  • 怎么做网站链接的快捷方式做一个网站怎么做的吗
  • .net给网站做短信验证wordpress需要登录才可以看到内容
  • 设计师在线网站电子商务网站建设的开发方案
  • 快排做网站排名wordpress自适应 the7
  • asp sqlite网站空间合肥高端网站
  • 厦门网站开发培训能盈利的网站
  • 网站架构模式用哪种智通人才网东莞最新招聘信息官网
  • 电商网站如何提高转化率阿里云二级域名建设网站
  • 网站的链接结构包括网络服务禁用后如何启动
  • 北京网站优化外包怎么做网站网站推广
  • 无锡建设银行官网招聘网站网站链接提交收录
  • 华强北做电子网站凡客精选带货达人