Несколько строк:: найти
Есть ли такой способ, как "if, for loop" или что-то для поиска первой и второй строки, и если нет строковых вхождений для поиска третьей.
Я застрял в этой тройке. Мне нужно как-то проверить, есть ли строка "aba" в первой и второй, но если нет, чтобы проверить "aba" в третьей строке. Некоторые идеи? Tnx заранее.
#include <iostream>
#include <string.h>
using namespace std;
int main() {
string s1, s2, s3;
string aba = "aba";
cout << "Input s1, s2: ";
cin >> s1;
cin >> s2;
s3 = s1 + s2;
cout << "String s3 is: " << s3;
cout << "\n\n****************************\n";
size_t found = s1.find(aba);
if(found!=string::npos){
cout << "Have for s1.";
}
size_t found1 = s2.find(aba);
if(found1!=string::npos){
cout << "Have for s2.";
}
size_t found2 = s3.find(aba);
if(found2!=string::npos){
cout << "Have for s3.";
}
}
2 ответа
Решение
Не уверен, что вы подразумеваете под лучшим, но сохраняя имена переменных, это немного чище, ИМХО.
if( ( found != string::npos ) && ( found1 != string::npos ) )
{
cout << "There is for s1 i s2.\n";
}
else
{
cout << "Don't have for s1 i s2, search in s3.\n";
if( found2 != string::npos )
{
cout << "There is for s3.\n";
}
else
{
cout << "Don't have for s3.\n";
}
}
Оператор && будет закорочен, и в коде нет повторения строк. Если вам нужно изменить строки (хотя это кажется игрушечным примером, и я сомневаюсь в этом), вы можете сделать это только в одном месте (незначительное применение принципа СУХОЙ).
Наконец-то сделал это, но так ли это лучше?
if(found != string::npos){
if(found1 != string::npos){
cout << "\nThere is for s1 i s2.";
} else {
cout << "\nDon't have for s1 i s2, search in s3.";
if(found2 != string::npos){
cout << "\nThere is for s3.";
} else {
cout << "\nDon't have for s3.";
}
}
} else {
cout << "\nDon't have for s1 i s2, search in s3.";
if(found2 != string::npos){
cout << "\nThere is for s3.";
} else {
cout << "\nDon't have for s3.";
}
}