维基百科:字符串是由零个或多个字符组成的有限序列。一般记为
s = a1a2...an
。它是编程语言中表示文本的数据类型。
我们知道,字符串与数组有很多相似之处,比如使用 名称[下标]
来得到一个字符。那么我们为什么要单独讨论字符串呢?原因主要有:
例如有这样一个字符串序列:I like leetcode
现在你想把这句话反向输出,可能会变成这样:
edocteel ekil I
这是我们想要的结果吗?你可能会回答不是,因为它没有任何意义。我们通常希望单词仍然维持原来的顺序,这样反向输出之后就是:
Leetcode like I
这样的结果对于我们来讲是不是更满意呢?维持单词本身的顺序使得我们方便更多操作,这里的每个单词就叫做字符串的「子串」,通常,我们的操作对象更多情况下是这些子串。
对于不同的编程语言,字符串的某些操作会有所不同。下面我们将从字符串的「比较」和「连接」操作两个方面分别进行讲解。
字符串有它自己的比较函数(我们将在下面的代码中向你展示比较函数的用法)。
然而,存在这样一个问题:
我们可以用
==
来比较两个字符串吗?
这取决于下面这个问题的答案:
我们使用的语言是否支持运算符重载?
yes
(例如 C++、Python)。我们可以使用 ==
来比较两个字符串;no
(例如 Java),我们可能无法使用 ==
来比较两个字符串。当我们使用 ==
时,它实际上会比较这两个对象是否是同一个对象。对于不同的编程语言中,字符串可能是可变的,也可能是不可变的。不可变意味着一旦字符串被初始化,你就无法改变它的内容。
什么是变位词?