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

网站建设怎么引流银川app购物网站制作公司

网站建设怎么引流,银川app购物网站制作公司,wordpress登录qq微信登录界面,网站设计网站制作目录 week21. 二维数组中的查找题目题解(单调性扫描) O(nm) 2.替换空格题目题解(线性扫描) O(n)(双指针扫描) O(n) 3.从尾到头打印链表题目题解(遍历链表) O(n) week2 1. 二维数组中的查找 题目 题解 (单调性扫描) O(nm) 核心在于发现每个子矩阵右上角的数的性质#xff1… 目录 week21. 二维数组中的查找题目题解(单调性扫描) O(nm) 2.替换空格题目题解(线性扫描) O(n)(双指针扫描) O(n) 3.从尾到头打印链表题目题解(遍历链表) O(n) week2 1. 二维数组中的查找 题目 题解 (单调性扫描) O(nm) 核心在于发现每个子矩阵右上角的数的性质 如下图所示x左边的数都小于等于xx下边的数都大于等于x。 因此我们可以从整个矩阵的右上角开始枚举假设当前枚举的数是 x 如果 x 等于target则说明我们找到了目标值返回true如果 x 小于target则 x 左边的数一定都小于target我们可以直接排除当前一整行的数如果 x 大于target则 x 下边的数一定都大于target我们可以直接排除当前一整列的数 排除一整行就是让枚举的点的横坐标加一排除一整列就是让纵坐标减一。 当我们排除完整个矩阵后仍没有找到目标值时就说明目标值不存在返回false。 时间复杂度分析 每一步会排除一行或者一列矩阵一共有 n 行m 列所以最多会进行nm 步。所以时间复杂度是 O(nm)。 class Solution { public:bool findNumberIn2DArray(vectorvectorint matrix, int target) {if (array.empty() || array[0].empty()) return false;int i 0, j array[0].size() - 1; // j 初始为右上角的位置while (i array.size() j 0) {if (array[i][j] target) return true;if (array[i][j] target) --j; // 锁定当前行排除当前列else i; // 排除当前行往下搜索}return false;} };2.替换空格 题目 题解 (线性扫描) O(n) 这个题在C里比较好做我们可以从前往后枚举原字符串 如果遇到空格则在string类型的答案中添加 %20如果遇到其他字符则直接将它添加在答案中 但在C语言中我们没有string这种好用的模板需要自己malloc出char数组来存储答案。 此时我们就需要分成三步来做 遍历一遍原字符串计算出答案的最终长度malloc出该长度的char数组再遍历一遍原字符串计算出最终的答案数组 时间复杂度分析 原字符串只会被遍历常数次所以总时间复杂度是 O(n)。 class Solution { public:string replaceSpaces(string str) {string res;for (auto x : str)if (x )res %20;else res x;return res;} };(双指针扫描) O(n) 在部分编程语言中我们可以动态地将原数组长度扩大此时我们就可以使用双指针算法来降低空间的使用 首先遍历一遍原数组求出最终答案的长度length将原数组resize成length大小使用两个指针指针i指向原字符串的末尾指针j指向length的位置两个指针分别从后往前遍历如果str[i] 则指针j的位置上依次填充0, 2, %这样倒着看就是%20如果str[i] ! 则指针j的位置上填充该字符即可。 由于i之前的字符串在变换之后长度一定不小于原字符串所以遍历过程中一定有i j这样可以保证str[j]不会覆盖还未遍历过的str[i]从而答案是正确的。 时间复杂度分析 原字符串只会被遍历常数次所以总时间复杂度是 O(n)。 class Solution { public:string replaceSpaces(string str) {int len 0;for (auto c : str)if (c ) len 3;else len;//str.size() 字符串中有几个字符大小就为几 //定义两个指针字符串的长度和实际下标位置差1int i str.size() - 1, j len - 1; str.resize(len); //调整字符串大小while (i 0) {if (str[i] ) {str[j--] 0;str[j--] 2;str[j--] %;}else str[j--] str[i];i--;}return str;} };3.从尾到头打印链表 题目 题解 (遍历链表) O(n) 单链表只能从前往后遍历不能从后往前遍历。 因此我们先从前往后遍历一遍输入的链表将结果记录在答案数组中。 最后再将得到的数组逆序即可。 语法补充 begin 语法iterator begin(); 解释begin()函数返回一个迭代器,指向字符串的第一个元素. end 语法iterator end(); 解释end()函数返回一个迭代器指向字符串的末尾(最后一个字符的下一个位置). rbegin 语法const reverse_iterator rbegin(); 解释rbegin()返回一个逆向迭代器指向字符串的最后一个字符。 rend 语法const reverse_iterator rend(); 解释rend()函数返回一个逆向迭代器指向字符串的开头第一个字符的前一个位置。 时间复杂度分析 链表和答案数组仅被遍历了常数次所以总时间复杂度是 O(n)。 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode(int x) : val(x), next(NULL) {}* };*/ class Solution { public:vectorint printListReversingly(ListNode* head) {vectorint res;while (head) {res.push_back(head-val);head head-next;}return vectorint(res.rbegin(), res.rend()); //反向迭代器} };
http://www.zqtcl.cn/news/177195/

相关文章:

  • 给周杰伦做网站广州免费景点
  • 网站文章不显示淄博网站建设及托管
  • 国外免费建站平面广告设计案例
  • 微信微网站开发价格广西做网站的公司有哪些
  • 做网站内容哪家公司可以做网站
  • 网站后台数据库管理经常浏览不良网站会被记录吗
  • 做加工都在哪个网站推广网络营销外包推广
  • 做英文网站怎么赚钱经典logo设计案例分析
  • 大型建站公司是干嘛的wordpress激活码充值
  • 带后台网站模板wordpress注册模板
  • 济南城乡住房建设厅网站dedecms企业网站
  • 旅游网站怎么做才能被关注园林景观设计公司名字
  • 建站之星网站建设系统事业单位网站登录模板
  • 如何做京东优惠券网站建设银行网站储蓄账户查询密码
  • 月付购物网站建站方维网络科技有限公司
  • 广东外贸网站建设企业手写代码网站
  • 信誉好的菏泽网站建设自己做网站一定要实名吗
  • 头像网站模板长春建工集团官网
  • 微信网站建设费用网站建设评价标准
  • 济宁市建设工程招投标网站购物网站建设图标大全
  • 婚恋网站制作网站建设服务案例
  • 学校 网站建设 报销discuz做网站赚钱经历
  • 上海做高端网站制小吃加盟招商方案
  • 焦作市建设工程网站网站开发遵循的原则
  • 网站搜索引擎优化主要方法分子信标探针在线设计网站
  • 湘潭做网站 定制磐石网络建设规划许可证公示网站
  • seo查询 站长工具热门行业
  • 广州网站设计与制作公司windows优化大师官方下载
  • 找公司做网站要注意什么网站优化方法页面
  • 贵州省都匀市网站建设it培训机构培训排名