C++ check if item is in a array [duplicate]

☆樱花仙子☆ 提交于 2019-12-22 19:41:22

问题


In c++ I have an array and I am trying to check if there is a certain element in the array. Here is my array:

string choices[3] = {"a", "b", "c"}

I want it so that it prints out true if the user input is present in the array so if the user enters "b" then it will print true and give me the array index. This is like the Python version of in or find. I know I can just use a for loop to go over all the elements, but is there a more efficient way? Thanks.


回答1:


To find index you can use the following code:

int x = std::distance(choices, std::find(choices, choices + 3, "b"));

here, distance and find method can be found in <algorithm> header.




回答2:


You can use standard algorithm std::find declared in header <algorithm> It resolves two tasks. It can say whether a string is present in a container and it can provide the index of the first found element.

If you need only to determine whether a string is present in a container you can use standard algorithm std::any_of

The both algorithms have linear complexity.

If a container (for example an array) is ordered then you can use standard algorithm std::binary_search to determine whether a string is present in the container.

An example that demonstrates the usage of standard algorithm std::find

#include <iostream>
#include <iomanip>
#include <string>
#include <algorithm>
#include <iterator>

int main()
{
   std::string choices[] = { "a", "b", "c" };

   std::cout << "Enter a string: ";

   std::string s;
   std::cin >> s;

   auto it = std::find( std::begin( choices ), std::end( choices ), s );

   bool in_array = it != std::end( choices );

   std::cout << "String "\" << s << "\" is present in the array = " 
             << std::boolalpha << in_array << std::endl;
   if ( in_array ) 
   {
      std::cout << "It is " << std::distance( std::begin( choices ), it ) 
                << " element in the array" << std::endl;
   }
}

If you need a more complex condition searching an element in a container you can use standard algorithm std::find_if that accepts a predicate as an argument.




回答3:


std::find returns an iterator to the element in the array if it's found or the end iterator otherwise:

auto const last = std::end(choices);
auto const pos = std::find(std::begin(choices), end, "b");
if (last != pos) {
    // Use pos here.
}

If you don't need to do anything with the element then you can use any_of:

if (std::any_of(std::begin(choices), std::end(choices),
                [](std::string const& s) { return "b" == s; })
{
    // "b" is in the array.
}

Both of these functions are just loops internally, they won't be any quicker than a hand written loop. If your array is sorted then you can use std::lower_bound instead of std::find and std::binary_search instead of std::any_of.




回答4:


There is no more efficient way unless the items are somehow ordered. Consider that the element you want to find could, theoretically, be at any index, including the last index that you would check.

If you want to find it efficiently, use std::set. Then you can use set::count(item) > 0 to decide if item is in the set.

Also, in python, it effectively does a loop over all elements when you test whether an item is in a list item in [itemA, itemB, itemC] or in a tuple item in (itemA, itemB, itemC). It is only when you use python's set and frozenset that this search is very fast.

I would recommend using the function std::find if you don't want to write the O(n) loop yourself, and using the std::set class if you want faster lookup.



来源:https://stackoverflow.com/questions/21830425/c-check-if-item-is-in-a-array

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!