一、从"banana", “orange”, “apple”, "grape"中找到apple
要在C++中将一个字符串和一个字符串数组进行比较,并输出数组中包含该字符串的元素,可以使用循环遍历数组,并使用字符串的compare()函数来比较每个元素是否与该字符串相等。如果相等,则输出该元素。
以下是一个示例代码,展示了如何实现这个功能:
#include <iostream>
#include <string>
using namespace std;
int main() {
string str = "apple";
string arr[] = {"banana", "orange", "apple", "grape"};
int len = sizeof(arr) / sizeof(arr[0]);
for (int i = 0; i < len; i++) {
if (str.compare(arr[i]) == 0) {
cout << "The string '" << str << "' is in the array at index " << i << endl;
}
}
return 0;
}
在上面的代码中,我们创建了一个字符串str,以及一个包含四个元素的字符串数组arr。我们使用循环遍历数组中的每个元素,并使用compare()函数将其与该字符串进行比较。如果相等,我们输出该元素及其索引。
请注意,我们使用sizeof()函数来获取数组的长度,并将其除以一个元素的大小,以获取数组中元素的数量。这样可以确保我们循环遍历整个数组。
二、从"banana", “orange”, “apple”, "grape"中找到app
如果要比较的字符串可以是字符串数组中的字符串的一部分,可以使用字符串的find()函数来查找该字符串是否在数组元素中出现。如果该字符串在数组元素中出现,find()函数将返回该子字符串在该数组元素中的索引位置;否则,将返回string::npos。
以下是一个示例代码,展示了如何实现这个功能:
#include <iostream>
#include <string>
using namespace std;
int main() {
string str = "app";
string arr[] = {"banana", "orange", "apple", "grape"};
int len = sizeof(arr) / sizeof(arr[0]);
for (int i = 0; i < len; i++) {
if (arr[i].find(str) != string::npos) {
cout << "The string '" << str << "' is part of the array element '" << arr[i] << "' at index " << i << endl;
}
}
return 0;
}
在上面的代码中,我们创建了一个字符串str,它是一个要比较的子字符串,以及一个包含四个元素的字符串数组arr。我们使用循环遍历数组中的每个元素,并使用find()函数在该数组元素中查找该子字符串。如果该子字符串在数组元素中出现,我们输出该元素及其索引。
请注意,我们将find()函数的返回值与string::npos进行比较,以确定该子字符串是否在数组元素中出现。如果find()函数返回的索引位置不等于string::npos,则该子字符串在数组元素中出现。