目录
递归算法生成后续字符串
后续数组的语法
跟随的方法
使用 C++ 转换字符串
示例5
输出
使用C++对字符串进行一元操作
Example 5
使用C++对字符串进行二进制操作
使用C++打印所有后续字符串
将字符串转换为其具有abcd…z作为子序列
结论
首页 后端开发 C++ 将一个字符串转换为其具有abcd..z作为子序列的形式

将一个字符串转换为其具有abcd..z作为子序列的形式

Sep 01, 2023 pm 02:17 PM
字符串转换 子序列形式 字母序列转换

将一个字符串转换为其具有abcd..z作为子序列的形式

字符串转换(也称为字符串转换)是 C++ 中的一种操作,在整个过程执行后,将结果存储在输出数组中。在C++中,有一个名为“transform()”的函数,存在于C++环境的目录中,通过它我们可以将字符串转换为新的字符串。

有两种形式的转换函数−

  • 一元运算

    • 操作应用于输入数组的每个元素。

    • 手术完成后,结果将存储在一个输出数组中。

  • 二元操作

  • 操作适用于特定数组的每个元素。

  • 第一个输入元素和第二个相应的输入元素参与了操作。

  • 输出数据将存储在一个输出数组中。

子序列字符串是由对输入字符串执行各种操作(例如:删除)生成的全新字符串。对于子序列字符串,操作发生时不会影响剩余的字符。

对于字符串转换,输入包含长度为n+1的操作字符串。原始字符属于a到z的系列。打印字符串的长度在这里被视为n,这里是一个输出字符串。

在本文中,我们将学习如何在C++环境中转换一个字符串,使其具有abcd….z作为一个子序列。

递归算法生成后续字符串

通过使用递归方法,下面是一个可能的算法用于一个后续字符串。这是特定的字符串,T是完成操作所需的时间。

  • 步骤 1 - 计算出现次数。

  • 步骤2 - 如果i = length(s)且j = length(T)。

  • 第三步−然后返回1。

  • 第4步 - 结束。

  • 步骤5 - 如果i = length(S)。

  • 步骤6 - 然后返回0。

  • 第7步 - 结束。

  • 步骤 8 − 计数

  • 步骤9 - 如果,j

  • 步骤10 − Count

  • 第11步 - 结束。

  • 第12步 - Count

  • 第13步 - 返回计数。

  • 第14步 - 结束。

后续数组的语法

Here, we have two given sequences. X and Y.
Initialize a table with a dimension of X.length * Y.length
X.label1 = X
Y.label2 = Y
CS1[0][] = 0
CS2[][0] = 0
Start from CS[1][1]
Compare X[i] and Y[j]
   If
      X[i] = Y[j]
      CS[i][j] = 1 + CS[i-1, j-1]
      Point an arrow to CS[i][j]
   Else
      CS[i][j] = max(CS[i-1][j], CS[i][j-1])
      Point an arrow to max(CS[i-1][j], CS[i][j-1])
登录后复制

这里我们创建了一个后续数组的基本工作语法。当有两个序列时,我们必须按照以下步骤来获取输出。

跟随的方法

  • 方法1−使用C++转换字符串

  • 通过使用C++对字符串进行一元操作的方法2

  • 使用C++对字符串进行二进制操作的方法3

  • 使用C++打印所有可能的后续字符串

  • 使用C++将字符串转换为具有abcd….z作为子序列的方法5

使用 C++ 转换字符串

在这段C++代码中,我们创建了一个新的字符串,并从输入字符串中删除了所有的元音字母。在这些元音字母的位置上添加了#。

示例 1

#include <bits/stdc++.h>
using namespace std;
string change_case(string r) {
   int l = r.length();
   for(int i = 0 ; i < l ; i++) {
      if(r[i] >= 'a' && r[i] <= 'z')
      r[i] = r[i] - 32;
      else if(r[i] >= 'A' && r[i] <= 'Z')
      r[i] = r[i] + 32;
   }
   return r;
}
string delete_vowels(string a) {
   string temp = "";
   int l = a.length();
   for(int i = 0 ; i < l ; i++) {
      if(a[i] != 'a' && a[i] != 'e' &&
      a[i] != 'i' && a[i] != 'o' &&
      a[i] != 'u' && a[i] != 'A' &&
      a[i] != 'E' && a[i] != 'O' &&
      a[i] != 'U'&& a[i] != 'I')
      temp += a[i];
   }
   return temp;
}
string insert_hash(string a) {
   string temp = "";
   int l = a.length();
   for(int i = 0 ; i < l ; i++) {
      if((a[i] >= 'a' && a[i] <= 'z') ||
      (a[i] >= 'A' && a[i] <= 'Z'))
      temp = temp + '#' + a[i];
      else
      temp = temp + a[i];
   }
   return temp;
}
void transformSting(string a) {
   string b = delete_vowels(a);
   string c = change_case(b);
   string d = insert_hash(c);
   if(d=="")
   cout<<"-1"<<endl;
   else
   cout << d<<endl;
}
int main() {
   string a = "RudraDevDas!!";
   string b = "aeiou";
   transformSting(a);
   transformSting(b);
   return 0;
}
登录后复制

输出

#r#D#R#d#V#d#S!!
-1
登录后复制

使用C++对字符串进行一元操作

在这段特定的代码中,我们展示了如何对输入数组进行一元操作。该函数接受一个指向单个输入的起始和结束位置的指针。并在输出数组的起始位置进行操作。

Example 2

的中文翻译为:

示例2

#include <iostream>
#include <algorithm>
using namespace std;
int op_increment (int x) {
   x = x + 1;
   return x;
}
int main () {
   int n = 5;
   int input_array[] = {7, 16, 10, 97, 2001};
   int output_array[n];
   std::cout << "Input array present here:";
   for(int i=0; i<5; i++){
      cout << ' ' << input_array[i];
   }
   cout << '\n';
   transform (input_array, input_array+5, output_array, op_increment);
   std::cout << "The output array now contains with:";
   for(int i=0; i<5; i++){
      cout << ' ' << output_array[i];
   }
   cout << '\n';
   return 0;
}
登录后复制

输出

Input array present here: 7 16 10 97 2001
The output array now contains with: 8 17 11 98 2002
登录后复制

使用C++对字符串进行二进制操作

在这段特定的代码中,我们展示了如何在输入数组上进行二进制操作。函数transform()在起始点和第一个输入数组之间添加了一个指针。请记住,二进制操作总是在两个输入数据集上进行。

Example 3

的中文翻译为:

示例 3

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
int op_add (int i, int j) {
   return i+j;
}
int main () {
   int n = 5;
   int arr1[] = {7, 16, 10, 2001, 1997};
   int arr2[] = {1, 2, 3, 4, 5};
   int output[n];
   std::cout << "Input data in array1:";
   for(int i=0; i<n; i++){
      cout << ' ' << arr1[i];
   }
   cout << '\n';
   std::cout << "Input data in array2:";
   for(int i=0; i<n; i++){
      cout << ' ' << arr2[i];
   }
   cout << '\n';
   std::transform (arr1, arr1+n, arr2, output, op_add);
   std::cout << "Output array is here now:";
   for(int i=0; i<5; i++){
      cout << ' ' << output[i];
   }
   cout << '\n';
   return 0;
}
登录后复制

输出

Input data in array1: 7 16 10 2001 1997
Input data in array2: 1 2 3 4 5
Output array is here now: 8 18 13 2005 2002
登录后复制

使用C++打印所有后续字符串

应用选择和不选择的概念来找出特定数组的所有子序列。在这个过程中,可能会删除一些字符而不改变元素的顺序。在这里,这个过程的时间复杂度是O(2^n),空间复杂度是O(n)。

示例 4

#include <bits/stdc++.h>
using namespace std;
void printSubsequence(string input, string output) {
   if (input.empty()) {
      cout << output << endl;
      return;
   }
   printSubsequence(input.substr(1), output + input[0]);
   printSubsequence(input.substr(1), output);
}
int main() {
   string output = "";
   string input = "rudraabonikoaa";
   printSubsequence(input, output);
   return 0;
}
登录后复制

输出

rudraabonikoaa
rudraabonikoa
rudraabonikoa
rudraaboniko
rudraabonikaa
rudraabonika
rudraabonika
rudraabonik
rudraabonioaa
rudraabonioa
rudraabonioa
rudraabonio
rudraaboniaa
rudraabonia
rudraabonia
登录后复制

将字符串转换为其具有abcd…z作为子序列

这是一种特定的过程,用于将字符串转换为具有abcd...z作为子序列的形式。

  • 初始化字符。

  • 如果长度小于26,则返回false。

  • 迭代循环从0到s.size() - 1。

  • 如果字符达到z,则跳出循环。

  • 如果当前字符小于s或等于字符。

  • 将当前字符的增量替换为1。

  • 如果字符小于或等于 z,则返回 false。

  • 否则,返回true。

在这个过程中,时间复杂度为O(n),辅助空间为O(1)。这里,n是特定字符串的长度。

Example 5

的中文翻译为:

示例5

#include <bits/stdc++.h>
using namespace std;
bool transformString(string& s) {
   char ch = 'a';
   if (s.size() < 26)
   return false;
   for (int i = 0; i < s.size(); i++) {
      if (int(ch) > int('z'))
      break;
      if (s[i] <= ch) {
         s[i] = ch;
         ch = char(int(ch) + 1);
      }
   }
   if (ch <= 'z')
   return false;
   return true;
}
int main() {
   string str = "aaaaaaaaaaaaaaaaaaaaaaaaaaa";
   if (transformString(str))
   cout << str << endl;
   else
   cout << "Not Possible" << endl;
   return 0;
}
登录后复制

输出

abcdefghijklmnopqrstuvwxyza
登录后复制

结论

在本文中,我们学习了使用C++环境进行字符串转换及其不同形式。通过遵循特定的算法和语法,我们检查和构建了一些不同的C++代码,并了解了如何转换字符串,使其具有abcd...z作为子序列。

以上是将一个字符串转换为其具有abcd..z作为子序列的形式的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1673
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
使用Boolean类的parseBoolean()方法将字符串转换为布尔值的方法 使用Boolean类的parseBoolean()方法将字符串转换为布尔值的方法 Jul 26, 2023 pm 08:17 PM

使用Boolean类的parseBoolean()方法将字符串转换为布尔值的方法在Java编程中,经常会遇到需要将字符串转换为布尔值的情况。而Java中的Boolean类提供了一个非常方便的方法——parseBoolean(),可以将字符串转换为对应的布尔值。本文将详细介绍这个方法的使用,并提供相应的代码示例。首先,我们需要了解parseBoolean()方

用PHP将字符串转换为16进制并实现反向输出 用PHP将字符串转换为16进制并实现反向输出 Mar 21, 2024 pm 03:33 PM

标题:使用PHP实现字符串转换为16进制并实现反向输出在日常开发中,我们有时候需要将字符串转换为16进制表示,以便进行数据传输或加密处理。本文将介绍如何使用PHP实现将字符串转换为16进制,并实现反向输出的功能。首先,我们需要编写一个PHP函数,来实现将字符串转换为16进制的功能。以下是一个示例代码:functionstringToHex($string)

使用java的Double.parseDouble()函数将字符串转换为双精度浮点数 使用java的Double.parseDouble()函数将字符串转换为双精度浮点数 Jul 26, 2023 am 09:25 AM

使用Java的Double.parseDouble()函数将字符串转换为双精度浮点数在Java编程中,我们经常需要将字符串转换为数值类型。对于双精度浮点数,Java提供了一个非常方便的方法,即Double.parseDouble()函数。本文将介绍该函数的用法,并附上一些示例代码,帮助读者更好地理解和使用该函数。Double.parseDouble()函数是

如何使用Python的upper()函数将字符串转换为大写 如何使用Python的upper()函数将字符串转换为大写 Nov 18, 2023 pm 01:14 PM

如何使用Python的upper()函数将字符串转换为大写,需要具体代码示例Python是一种简单易学的编程语言,它提供了许多内置函数来处理字符串。其中一种常用的函数是upper()函数,它可以将字符串中的所有字母转换为大写形式。本文将详细介绍如何使用Python的upper()函数,并提供相应的代码示例。首先,让我们来了解一下upper()函数的用法。up

快速学会在Go语言中进行字符串到数组的转换 快速学会在Go语言中进行字符串到数组的转换 Mar 12, 2024 pm 10:27 PM

快速学会在Go语言中进行字符串到数组的转换在Go语言中,字符串与数组之间的转换是一个常见的操作,特别是在处理数据时经常会遇到需要将字符串转换为数组的情况。本文将介绍如何在Go语言中快速学会实现字符串到数组的转换,让你能够轻松应对类似的问题。在Go语言中,我们可以使用strings包提供的Split函数来将字符串按照指定的分隔符拆分成一个数组。以下是一

使用strconv.ParseInt函数将字符串转换为指定进制的整数 使用strconv.ParseInt函数将字符串转换为指定进制的整数 Jul 24, 2023 pm 03:33 PM

使用strconv.ParseInt函数将字符串转换为指定进制的整数尽管Go语言中的strconv包提供了许多用于类型转换的函数,但有时我们仍然需要自定义的类型转换。当我们需要将字符串转换为指定进制的整数时,可以使用strconv.ParseInt函数来完成。strconv.ParseInt函数的参数包括要转换的字符串、指定的进制和结果整数的位数。它返回转换

如何使用C#中的Enum.Parse函数将字符串转换为枚举类型的值 如何使用C#中的Enum.Parse函数将字符串转换为枚举类型的值 Nov 18, 2023 am 11:44 AM

如何使用C#中的Enum.Parse函数将字符串转换为枚举类型的值在C#中,枚举(Enum)是一种用于声明一组相关常量的数据类型。当我们需要将字符串转换为枚举类型的值时,可以使用Enum.Parse函数来实现。本文将详细介绍如何使用Enum.Parse函数,并给出具体的代码示例。Enum.Parse函数是一个强大的方法,它可以从指定的字符串中尝试解析出枚举类

在Java中将字符串转换为StringBuilder 在Java中将字符串转换为StringBuilder Sep 02, 2023 pm 03:57 PM

StringBuilder类的append()方法接受String值并将其添加到当前对象。将字符串值转换为StringBuilder对象-获取字符串值。附加使用append()方法将字符串获取到StringBuilder。示例在下面的Java程序中,我们是将字符串数组转换为单个StringBuilder对象。 实时演示publicclassStringToStringBuilder{  publicstaticvoidmain(Stringargs[]){&a

See all articles