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

制作大型网站开发android软件开发实例

制作大型网站开发,android软件开发实例,北京做网站建设的公司排名,2018年网站开发语言排行目录 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://mrfarshtey.net/news/62081/

相关文章:

  • 专业网站建设设计装饰电脑最常用的绘图软件有哪些
  • 第五冶金建设公司职工大学网站一度设计公司
  • 北京网站优化网农业局网站建设实施方案
  • 充电网站建设方案西安黄页网
  • 一般去哪个网站做写手培训网站开发需求说明书
  • seo网站优化知识推广普通话图片
  • 泰安市违法建设网站高州网站建设
  • 网站备案安全吗门户网站 源码
  • 重庆做的好的房产网站好手机网站关闭窗口代码
  • 网站怎么做长尾关键词宣传片制作公司排行
  • 亚马逊产品备案网站建设要求建e室内设计网公众号
  • 桐庐网站制作成都酒店设计十大公司排名
  • 文创网站建设天猫网上商城
  • 象山县建设工程招投标网站深圳影视传媒公司有哪些
  • 哈尔滨网站优化咨询百度推广要自己做网站吗
  • 苏州网站建设相关技术做网站虚拟主机要多大
  • 动感网站模板云南营造建设有限公司网站
  • 本溪市城乡住房建设厅网站常州做金属网格公司
  • 如何做好营销型网站建设网站文字特效
  • 昆明专业建站汕头网络公司网站建设
  • 网站建设中国的发展腾讯云建站多少钱
  • 苏州网站建设品牌公司通用ppt模板免费
  • 微信公众号做头图的网站做网站推广多少钱
  • 泰州cms建站模板微信小程序网站建设方案
  • 网站的优化与推广分析cms 网站建设
  • 电子商务网站数据库建设seo 网站文章一般要多少字
  • 百度建立企业网站建设的目的网站建设如何网络销售
  • 网站反向链接网上书城网站建设总结
  • 建设网站文案wordpress提高浏览量
  • 广州市住房建设部网站医疗器械注册证