字符串

维基百科:字符串是由零个或多个字符组成的有限序列。一般记为 s = a1a2...an。它是编程语言中表示文本的数据类型。

我们知道,字符串与数组有很多相似之处,比如使用 名称[下标] 来得到一个字符。那么我们为什么要单独讨论字符串呢?原因主要有:

  1. 字符串的基本操作对象通常是字符串整体或者子串

例如有这样一个字符串序列:I like leetcode 现在你想把这句话反向输出,可能会变成这样:

edocteel ekil I

这是我们想要的结果吗?你可能会回答不是,因为它没有任何意义。我们通常希望单词仍然维持原来的顺序,这样反向输出之后就是:

Leetcode like I

这样的结果对于我们来讲是不是更满意呢?维持单词本身的顺序使得我们方便更多操作,这里的每个单词就叫做字符串的「子串」,通常,我们的操作对象更多情况下是这些子串。

  1. 字符串操作比其他数据类型更复杂(例如比较、连接操作)

对于不同的编程语言,字符串的某些操作会有所不同。下面我们将从字符串的「比较」和「连接」操作两个方面分别进行讲解。

比较函数

字符串有它自己的比较函数(我们将在下面的代码中向你展示比较函数的用法)。

然而,存在这样一个问题:

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

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

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

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

连接操作

对于不同的编程语言中,字符串可能是可变的,也可能是不可变的。不可变意味着一旦字符串被初始化,你就无法改变它的内容。

  • 在某些语言(如 C ++)中,字符串是可变的。 也就是说,你可以像在数组中那样修改字符串。
  • 在其他一些语言(如 Java、Python)中,字符串是不可变的。

变位词

什么是变位词?