Leetcode数据结构&算法:数组和字符串

一、介绍

数组就不介绍了,一维、二维、动态等,最基本的数据结构吧。

字符串使用时需要注意,在不同的语言里,情况不一样。

数组和字符串就简单记录下了。

(1)比较函数

字符串有它自己的比较函数

我们可以用 “==” 来比较两个字符串吗?

这取决于下面这个问题的答案:

我们使用的语言是否支持运算符重载

  1. 如果答案是 yes (例如 C++)。我们可以使用 “==” 来比较两个字符串。
  2. 如果答案是 no (例如 Java),我们可能无法使用 “==” 来比较两个字符串。当我们使用  “==” 时,它实际上会比较这两个对象是否是同一个对象。

(2)是否可变

 不可变意味着一旦字符串被初始化,你就无法改变它的内容。

  1. 在某些语言(如 C ++)中,字符串是可变的。 也就是说,你可以像在数组中那样修改字符串。
  2. 在其他一些语言(如  Java)中,字符串是不可变的。 此特性将带来一些问题。

 例如,如果字符串的长度是 N,那么查找操作和子字符串操作的时间复杂度是 O(N)。此外,在字符串不可变的语言中,你应该额外小心连接操作。在计算解决方案的时间复杂度时,不要忘记考虑内置操作的时间复杂度。

二、双指针

 通常,我们只使用从第一个元素开始并在最后一个元素结束的一个指针来进行迭代。 但是,有时候,我们可能需要同时使用两个指针来进行迭代。

典型场景之一

从两端向中间迭代数组。

这时你可以使用双指针技巧:

一个指针从始端开始,而另一个指针从末端开始。

这种技巧经常在排序数组中使用。

典型场景二

同时有一个慢指针和一个快指针。

解决这类问题的关键是

确定两个指针的移动策略。

与前一个场景类似,你有时可能需要在使用双指针技巧之前对数组进行排序,也可能需要运用贪心想法来决定你的运动策略。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值