字符的子序列
Sub-sequence of characters
本文关键字:字符 更新时间:2023-10-16
这里必须找到2个字符串中字符的语义序列。第一个字符串是"堆栈溢出">第二个字符串是用户输入,它可能包含也可能不包含字符串 1 作为字符的子序列。
即,stdachfdkoverrfloow 它包含 string1 数据作为子序列字符,然后输出应显示 YES
即,"stackoverway"它不包含 string1 数据作为子序列字符,然后输出应显示 NO
这是我的代码。
#include <bits/stdc++.h>
#include<iostream>
#include<cstring>
using namespace std;
bool SubSeq(char str1[], char str2[], int m, int n)
{
if (m == 0)
return true;
if (n == 0)
return false;
if (str1[m-1] == str2[n-1])
return SubSeq(str1, str2, m-1, n-1);
return SubSeq(str1, str2, m, n-1);
}
int main()
{
int q;
cin >> q;
for(int a0 = 0; a0 < q; a0++)
{
char str1[] = "stackoverflow";
int m = strlen(str1);
char str2[] = "";
cin >> str2;
int n = strlen(str2);
SubSeq(str1, str2, m, n) ? cout << "YESn" : cout << "NOn";
}
return 0;
}
在上面的代码中,我得到的输出如下。
YES
NO
NO
NO
NO
NO
NO
NO .......(truncated)
我不知道为什么这个NO发生这么多次。谁能告诉我我哪里做错了一步..
提前致谢
文卡特什
您将str2
声明为空,然后尝试将输入存储到其中。使用std::string
char str1[] = "stackoverflow";
int m = strlen(str1);
char str2[] = ""; //Notice the size of str2
cin >> str2;
您也可以遵循以下方法
继续在search_here
中搜索to_be_searched
的第一个字符。当找到i
位置时,从i+1
位置继续to_be_searched
和儿子的第二个角色。
bool check(string to_be_Searched,string search_here)
{
for(int i=0,j=0;j<to_be_searched.length() && i<search_here.length();i++)
{
if(to_be_Searched[j]==search_here[i])
j++;
}
return j==to_be_searched.length();
}
相关文章:
- C++字符*缓冲区的大小
- HEX值到wchar_t字符(UTF-8)的转换
- 为什么 Serial.println(<char[]>);返回随机字符?
- 我的字符计数代码计算错误.为什么
- 字符串-C++后显示的随机字符
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 如何在C++中从字符串中分割字符
- 为什么msgrcv()将垃圾字符馈送到缓冲区
- 指向指向字符数组的指针数组的指针
- 如何用转义符替换字符串中的所有特殊字符
- 为什么 sscanf 无法从一个字符串中读取uint64_t和字符?
- 比较字符数组
- 将字符指针十六进制转换为字符串并保存在文本文件C++中
- 从矢量<无符号字符>转换为字符* 包括垃圾数据
- 如何使用Crypto++并为RSA返回可打印的字节/字符数组
- 如何在C++中确定文本文件中的元素是字符还是数字
- 如何将一个ostringstream十六进制字符串字符对转换为单个unit8t等价的二进制值
- 为字符串中每 N 个字符插入空格的函数没有按照我认为的方式工作?
- C++中无符号字符溢出
- 使用无符号字符数组有效存储内存