Есть ли такой способ, как «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.";
}}
Не уверен, что вы подразумеваете под лучшим, но сохраняя ваши имена переменных, это немного чище имхо.
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.";
}
}