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

周浦网站建设公司跨界营销案例

周浦网站建设公司,跨界营销案例,新余做网站的,企业网站趋势文章目录反转字符串习题双指针swap 的两种方式反转字符串 本节对应代码随想录中:代码随想录,讲解视频:字符串基础操作! | LeetCode:344.反转字符串_哔哩哔哩_bilibili 习题 题目链接:344. 反转字符串 - …

文章目录

    • 反转字符串
      • 习题
      • 双指针
      • swap 的两种方式

反转字符串

本节对应代码随想录中:代码随想录,讲解视频:字符串基础操作! | LeetCode:344.反转字符串_哔哩哔哩_bilibili

习题

题目链接:344. 反转字符串 - 力扣(LeetCode)

编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。
不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。

示例 1:
输入:s = ["h","e","l","l","o"]
输出:["o","l","l","e","h"]

双指针

作为数组的第一题,这题还是比较简单的。反转字符串其实就是原来第一个字符变成最后一个字符,原来第二个字符变成倒数第二个字符,以此类推。那其实就是将第一个与最后一个字符交换,将第二个与倒数第二个字符交换,以此类推。并且我们只需要遍历字符串一半的长度就行交换即可。

class Solution {public:void reverseString(vector<char>& s) {int size = s.size();for (int i = 0, j = size - 1; i < size / 2; i++, j--) {swap(s[i], s[j]);}}
};
  • 时间复杂度:O(nnn)。有一个 for 循环,它的迭代次数是数组大小的一半,即 O(n/2),swap 函数交换了两个元素的值,其时间复杂度为 O(1)。因此,这个函数的时间复杂度为 O(n/2 * 1),也就是 O(n)
  • 空间复杂度:O(111)。只使用了常量级别的额外空间存储变量 i、j 和 size,因此空间复杂度为 O(1)

对于本题,其实使用库函数 reverse 就能解题,但显然本题并不是考察库函数的使用,面试的时候更不会如此。但是必须要了解可以使用什么库函数来实现,代码如下:

class Solution {public:void reverseString(vector<char>& s) {reverse(s.begin(),s.end());}
};
  • 时间复杂度:O(nnn)。只调用了一次 C++ 标准库中的 reverse 函数,其时间复杂度为 O(n),其中 n 是数组的大小
  • 空间复杂度:O(111)。没有使用任何额外的内存来存储变量,所以空间复杂度是 O(1)

swap 的两种方式

第一种是比较常见的方式

int tmp = s[i];
s[i] = s[j];
s[j] = tmp;

第二种是通过位运算

int a = 5; // 101
int b = 7; // 111
a ^= b; // 此时 a 的值为 2(101^111=010)
b ^= a; // 此时 b 的值为 5(010^111即(101^111)^111=101)
a ^= b; // 此时 a 的值为 7(010^101即(101^111)^101=111)

解释:利用异或运算符的特性(一个数异或同一个数两次会得到原始的值),这个交换操作不需要临时变量,比第一种方法更快,尤其是在处理大型数据集时。但要注意的是,这种方式只适用于整型数据类型,对于其他类型,例如浮点数、字符或自定义对象等,则需要采用其他方法进行交换。

解题的时候一般的交换元素可以直接用 swap 函数即 swap(a,b)

http://www.zhongyajixie.com/news/9474.html

相关文章:

  • 政府机关网站建设审批部门长沙seo优化排名推广
  • 建网站公司的资质需要哪些手机优化大师为什么扣钱
  • 12306网站是哪个公司做的seo单词优化
  • 百度惠生活推广怎么收费优化大师官网登录入口
  • wordpress移除自豪的使用太原seo排名
  • 做网站需要哪些基本功能竞价排名适合百度吗
  • 怎样学做企业网站google网站登录入口
  • wordpress 3.2.1漏洞seo代码优化
  • tp5企业网站开发长沙百度首页优化排名
  • 佛山网站建设网站长春网站制作公司
  • 襄樊和襄阳是一个地方吗seo做得比较好的企业案例
  • wordpress只能在局域网深圳seo优化服务商
  • 如何做自己网站的访问记录电脑培训学校
  • 网站开发前景建站系统cms
  • 三河网站建设知乎怎么申请关键词推广
  • 广告设计专业哪个大学最好站长工具查询seo
  • 免费学平面设计的网站google官网下载
  • 企业怎么建立网站昆明百度推广开户费用
  • 网站兼容9汕头最好的seo外包
  • 中国十大电商做的好的网站网络运营需要学什么
  • 平台网站可以做第三方检测报告今日热点新闻10条
  • 做流程图表的网站厦门网站建设公司名单
  • 深圳外贸公司网站建设公司排名百度账号客服
  • 搭建本地网站做色流大众网潍坊疫情
  • 网站建设与推广协议深圳seo推广培训
  • 长沙建站公司做网站宝鸡seo排名
  • 网站seo插件太原seo团队
  • 美国专门做特卖的网站网站设计的基本原则
  • 怎么做自己的公司网站惠州网站建设
  • 洛阳网站建设多少钱seo的中文意思