通过替换除第一个和最后一个字符之外的所有字符来缩写给定的字符串

data structurec++server side programming

在这个问题中,我们需要将长度大于 2 的字符串转换为其缩写形式。我们可以使用字符串的"length"属性来计算字符串中中间字符的总数,并且我们可以使用相应的索引值来计算第一个和最后一个字符。

问题陈述− 我们给出了一个长度大于或等于 2 的字符串 str,需要将字符串转换为其缩写形式。

字符串的缩写形式如下:第一个字符 + 中间字符总数 + 最后一个字符。

示例

输入

str = 'abcdefg'

输出

a5g

说明 − 'a' 为第一个字符,'g' 为最后一个字符,中间一共有 5 个字符。

输入

 str = 'tutorialspoint'

输出

t12t

解释− 这里,第一个和最后一个字符是't',中间字符总数为 12。

输入

 str = 'ab'

输出

a0b

解释− 这里,中间字符总数为 0,因此结果字符串为 a0b。

方法 1

在此方法中,我们将遍历字符串以查找字符串的长度。之后,我们将访问字符串的第一个和最后一个字符以进行缩写。

算法

步骤 1 - 定义"size"变量并用 0 初始化以存储给定字符串中的字符总数。

步骤 2 - 使用循环遍历字符串,直到我们得到"\0"作为当前字符。

步骤 3 - 打印字符串的第一个字符。

步骤 4 - 打印 size - 2。

步骤 5 - 使用"size - 1"索引打印字符串的最后一个字符。

示例

#include <iostream>
using namespace std;

void abbreviateWord(string alpha){
    int size = 0;
    // 计算字符总数
    while (alpha[size] != '\0')
    size++;
    // 第一个字符
    cout << alpha[0];
    // 中间所有字符
    cout << size - 2;
    // 最后一个字符
    cout << alpha[size - 1];
}
int main(){
    string str = "abcdefghi";
    abbreviateWord(str);
    return 0;
}

输出

a7i

时间复杂度− O(N),因为我们遍历字符串来计算字符串中的字符总数。

空间复杂度− O(1),因为我们不使用额外空间。

方法 2

在这种方法中,我们将使用 C++ 中字符串的 size() 方法来获取字符串的长度。

算法

步骤 1 − 使用字符串的长度初始化"len"变量,我们可以使用 size() 方法获取该长度。

步骤 2 − 使用"0"索引访问字符串的第一个字符,然后打印它。

步骤 3 − 打印"len − 2"。

步骤 4 − 打印字符串的最后一个字符字符串。

示例

#include <iostream>
using namespace std;
void abbreviateWord(string alpha) {
    // 获取字符串长度
    int len = alpha.size();
    // 第一个字符
    cout << alpha[0];
    // 打印 len - 2
    cout << len - 2;
    // 最后一个字符
    cout << alpha[len - 1];
}
int main() {
    string str = "tutorialspoint";
    abbreviateWord(str);
    return 0;
}

输出

t12t

时间复杂度− O(N),因为我们使用size()方法。

空间复杂度− O(1),因为我们不使用动态空间。

结论

在本教程中,我们学习了使用两种方法打印字符串的缩写。在第一种方法中,我们使用循环来计算字符串中的字符总数,在第二种方法中,我们使用size()方法。但是,程序员也可以使用length()方法。


相关文章