Как убедиться, что две строки имеют только определенные алфавиты в переполнении стека

Цель состоит в том, чтобы убедиться, что введенный пользователем ввод для строки 1 и строки 2 содержит только символы A, T, G или C в любом порядке. Если любая строка содержит другой другой символ, то должна отображаться ошибка. Пример:

Вход содержит ошибку

Ошибка в строке № 1: aacgttcOgMa

Ошибка в строке № 2: ggataccaSat

Это моя попытка кода файла LCS.cpp:

#include "LCS.h"#include <string>

using namespace std;

bool validate(string strX, string strY)
{

string x = strX;
string y = strY;
char searchItem = 'A';
char searchItem = 'C';
char searchItem = 'G';
char searchItem = 'T';
int numOfChar = 0;
int m = strX.length();
int n = strY.length();
for (int i = 0; i < m; i++)
{
if (x[i] == searchItem)
{
numOfChar++;

}
for (int i = 0; i < n; i++)
{
if (y[i] == searchItem)
{
numOfChar++;

}
}

}

Это мой код файла LCS.h:

#pragma once
#ifndef LCS_H
#define LCS_H

#include <string>

using namespace std;

bool validate(string strX, string strY);
#endif

И мой файл драйвера «Driver6.cpp» имеет этот код:

#include "LCS.h"#include <iostream>
#include <string>using namespace std;

int main()
{
string strX, strY;

cout << "String #1: ";
cin >> strX;
cout << "String #2: ";
cin >> strY;

//validate the input two strings
if (validate(strX, strY) == false)
{
return 0;
}

int m = strX.length();
int n = strY.length();

}

-2

Решение

На самом деле не хотел этого делать, но это кажется лучшим выбором, чем обходить дома в комментариях:

#include <string>
#include <iostream>

bool validate( const std::string & s ) {
for ( auto c : s ) {
if ( c != 'A' && c != 'T' && c != 'C' && c != 'G' ) {
return false;
}
}
return true;
}

int main() {
std::string s1 = "ATGCCCG";
std::string s2 = "ATGfooCCCG";

if ( validate( s1 ) ) {
std::cout << "s1 is valid\n";
}
else {
std::cout << "s1 is not valid\n";
}
if ( validate( s2 ) ) {
std::cout << "s2 is valid\n";
}
else {
std::cout << "s2 is not valid\n";
}
}
0

Другие решения

Другая техника:

bool validate(const std::string& s)
{
const static std::string valid_letters("ATCGatcg");
for (auto c: s)
{
std::string::size_type position = valid_letters.find_first_of(c);
if (position == std::string::npos)
{
return false;
}
}
return true;
}

Приведенный выше код ищет контейнер действительных букв.

0

По вопросам рекламы [email protected]