當前位置: 首頁>>代碼示例>>C++>>正文


C++ std::find方法代碼示例

本文整理匯總了C++中std::find方法的典型用法代碼示例。如果您正苦於以下問題:C++ std::find方法的具體用法?C++ std::find怎麽用?C++ std::find使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在std的用法示例。


在下文中一共展示了std::find方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。

示例1: url

static
bool
build_url(const string &line) // line from the input file
{
    try {
        oodles::url::URL url(line);
        cout << "Tokenised URL: " << url << endl;
        cout << "Domain, Path and Page document IDs: "
             << url.domain_id() << ", "
             << url.path_id() << ", "
             << url.page_id() << endl;

        cout << "Testing iterator access...";
        if (find(url.begin(), url.end(), "http") != url.end())
            cout << "(http scheme), ";

        if (find(url.begin(), url.end(), "index.html") != url.end())
            cout << "(.html index page), ";

        if (count(url.begin(), url.end(), "www") > 0)
            cout << "(www host).";
        cout << endl;

        cout << "Testing bidirectional iteratation...";
        for (oodles::url::URL::iterator i = url.end() ; i != url.begin() ; )
            cout << *(--i) << ",";
        cout << endl << endl;
    } catch (const exception &e) {
        cerr << e.what();
        return false;
    }

    return true;
}
開發者ID:jvanns,項目名稱:oodles,代碼行數:34,代碼來源:url-parser.cpp

示例2: do_type

 virtual const std::string do_type() const throw ()
 {
     //
     // A real application should use OS facilities for this.  This
     // is a crude hack.
     //
     using std::find;
     using std::string;
     using boost::algorithm::iequals;
     using boost::next;
     string media_type = "application/octet-stream";
     const string::const_reverse_iterator dot_pos =
         find(this->url_.rbegin(), this->url_.rend(), '.');
     if (dot_pos == this->url_.rend()
             || next(dot_pos.base()) == this->url_.end()) {
         return media_type;
     }
     const string::const_iterator hash_pos =
         find(next(dot_pos.base()), this->url_.end(), '#');
     const string ext(dot_pos.base(), hash_pos);
     if (iequals(ext, "wrl")) {
         media_type = "model/vrml";
     } else if (iequals(ext, "x3dv")) {
         media_type = "model/x3d+vrml";
     } else if (iequals(ext, "png")) {
         media_type = "image/png";
     } else if (iequals(ext, "jpg") || iequals(ext, "jpeg")) {
         media_type = "image/jpeg";
     }
     return media_type;
 }
開發者ID:jherico,項目名稱:ARToolkit,代碼行數:31,代碼來源:arViewer.cpp

示例3: do_type

		virtual const std::string do_type() const throw ()
		{
			//
			// A real application should use OS facilities for this.  This
            // is a crude hack because sdl-viewer uses std::filebuf in
            // order to remain simple and portable.
			//
			using std::find;
			using std::string;
			using boost::algorithm::iequals;
			using boost::next;
			string media_type = "application/octet-stream";
			const string::const_reverse_iterator dot_pos =
				find(this->url_.rbegin(), this->url_.rend(), '.');
			if (dot_pos == this->url_.rend()
				|| next(dot_pos.base()) == this->url_.end()) {
				return media_type;
			}
			const string::const_iterator hash_pos =
				find(next(dot_pos.base()), this->url_.end(), '#');
			const string ext(dot_pos.base(), hash_pos);
			if (iequals(ext, "wrl")) {
                media_type = openvrml::vrml_media_type;
			} else if (iequals(ext, "x3dv")) {
                media_type = openvrml::x3d_vrml_media_type;
			} else if (iequals(ext, "png")) {
				media_type = "image/png";
			} else if (iequals(ext, "jpg") || iequals(ext, "jpeg")) {
				media_type = "image/jpeg";
			}
			return media_type;
		}
開發者ID:hauptmech,項目名稱:artoolkit,代碼行數:32,代碼來源:arViewer.cpp

示例4: unite

 inline void unite(int x, int y) {
     x = find(x), y = find(y);
     if(x == y) { ans++; return; }
     if(rank[x] < rank[y]) {
         par[x] = y;
     } else {
         par[y] = x;
         rank[x] += rank[x] == rank[y];
     }
 }
開發者ID:GadyPu,項目名稱:OnlineJudge,代碼行數:10,代碼來源:2120+Ice_cream's+world+I.cpp

示例5: main

int main() {
    //input
    int a, b;
    scanf("%d%d", &n, &m);
    memset(g, false, sizeof(g));
    for (int i = 0; i < m; i++) {
        scanf("%d%d", &a, &b);
        g[a][b] = true;
    }

    //floyd
    for (int k = 1; k <= n; k++)
        for (int i = 1; i <= n; i++)
            for (int j = 1; j <= n; j++)
                if (g[i][k] && g[k][j]) g[i][j] = true;
    for (int i = 1; i <= n; i++) g[i][i] = true;

    //find all subsets of H
    find_h(1);
    //h[0]: empty set
    //h[1]: Max(X)
    swap(h[1], *find(h, h+num_h, max(H(true))));
    /**
     * pre-computing
     *
     * The results of the operations between items in H, consist a close
     * group of itself. This means that the results are also in H.
     */
    for (int i = 0; i < num_h; i++) {
        for (int j = 0; j < num_h; j++) {
            h_equalgreater[i][j] = find(h, h+num_h, equalgreater(h[i], h[j])) - h;
            h_intersection[i][j] = find(h, h+num_h, intersection(h[i], h[j])) - h;
            h_unionset[i][j] = find(h, h+num_h, unionset(h[i], h[j])) - h;
        }
    }

    //processing
    int k;
    scanf("%d\n", &k);
    while (k-- > 0) {
        cin.getline(s, MAXL);
        memset(alphabeta, -1, sizeof(alphabeta));
        for (char *p = s; *p; ++p) {
            if (isupper(*p))
                alphabeta[*p-'A'] = 0;
            else if (*p == '>') //simplify the input, "=>" --> ">"
                *(p-1) = ' ';
        }
        printf(solve(0)?"valid\n":"invalid\n");
    }

    return 0;
}
開發者ID:kerpoocoder,項目名稱:sgu-solution,代碼行數:53,代碼來源:sgu161.cpp

示例6: connect_face

void Mesh::connect_face(int u, int v) {
    if (u == v)
        return;
    if (find(adj_face[u].begin(), adj_face[u].end(), v) != adj_face[u].end())
        return;
    adj_face[u].push_back(v);
}
開發者ID:ComboZhc,項目名稱:Geo,代碼行數:7,代碼來源:mesh.cpp

示例7: removeEntity

void World::removeEntity(const shared_ptr<Entity> &entity) {
    auto it = find(m->entities.begin(), m->entities.end(), entity);
    if (it == m->entities.end()) {
        throw std::runtime_error("Entity is not there to remove!");
    }
    m->entities.erase(it);
}
開發者ID:Zetaeta,項目名稱:MCpp-Server,代碼行數:7,代碼來源:World.cpp

示例8: find

/*
 * Fetches a tile from a specific set specified by set_number
 * Returns the fetched tile.
 */
shared_ptr<Tile> Model::fetch_tile_from_set( int set_number, string tile_name ){
    Set* set = get_set_from_table( set_number );
    shared_ptr<Tile> tile = set->get_and_erase_tile( tile_name );

    if (tile->is_joker()) {
        tile->reset_joker();
    }
    
    cout << "Fetched " << tile->get_name() << " from set " << set_number << endl;

    // If there is only one tile left in set, fetch the remaining tile
    if (set->size() == 1) {
        string last_tile_name = set->get_tiles().front()->get_name();
        cout << "Automatically fecthed last tile " << last_tile_name << " from set " << set_number << " to hand" << endl;
        shared_ptr<Tile> last_tile = set->get_and_erase_tile( last_tile_name );

        if (last_tile->is_joker()) {
            last_tile->reset_joker();
        }

        Model::get_instance().add_fetched_tile_to_hand( last_tile );

        // Remove set since all tiles have been fetched
        auto it = find(table.begin(), table.end(), set);
        table.erase(it);
    }

    return tile;
}
開發者ID:chris4459,項目名稱:rummikub,代碼行數:33,代碼來源:Model.cpp

示例9: contains

bool contains(const table& tbl, int val)
  { // return true if tbl contains val
  int hash_val = hash(val) % tbl.size();
  bucket::const_iterator first = tbl[hash_val].begin();
  bucket::const_iterator last = tbl[hash_val].end();
  return find(first, last, val) != last;
  }
開發者ID:abo321,項目名稱:books-code,代碼行數:7,代碼來源:hashtable.cpp

示例10: goal

bool goal(const TCandidate              &candidate,
          const string::const_iterator  &query_end, 
		        float                   &min_suggestion_prob,
                vector<string>          &suggestions)
{
	if (candidate.node->sub_trees.size() > 0)  // leaf has no subtrees
		return false;

    if (candidate.query != query_end)  // query must be already matched at trie leaf
		return true;

	// remove string delimiter in trie
	string suggestion(candidate.suggestion.substr(0, candidate.suggestion.size() - 1));
	// no duplicates in results allowed
	if (find(suggestions.begin(), suggestions.end(), suggestion) == suggestions.end())
	{
		// set criterion that P(solution) must be greater that P(best solution) / 100 
		if (suggestions.empty())
			min_suggestion_prob = candidate.probability / (float)100.;

		suggestions.push_back(suggestion);
	}
	
	return true;
}
開發者ID:inetis,項目名稱:autocomplete,代碼行數:25,代碼來源:Autocomplete.cpp

示例11: Rename

void HelpConfigDialog::Rename(wxCommandEvent &event)
{
  wxListBox *lst = XRCCTRL(*this, "lstHelp", wxListBox);
  wxString orig = lst->GetString(lst->GetSelection());
  wxString text = wxGetTextFromUser(_("Rename this help file title:"), _("Rename title"), orig);

  if (!text.IsEmpty())
  {
    HelpCommon::HelpFilesVector::iterator logEnd = m_Vector.end() - HelpCommon::getNumReadFromIni();
    HelpCommon::HelpFilesVector::iterator it = find(m_Vector.begin(), logEnd, text);

    if (it != logEnd)
    {
      cbMessageBox(_("This title is already in use."), _("Warning"), wxICON_WARNING);
      return;
    }

    if (text.Find(_T('/')) != -1 || text.Find(_T('\\')) != -1)
    {
      cbMessageBox(_("Slashes and backslashes cannot be used to name a help file."), _("Warning"), wxICON_WARNING);
      return;
    }

    m_Vector[lst->GetSelection()].first = text;
    lst->SetString(lst->GetSelection(), text);
  }
}
開發者ID:469306621,項目名稱:Languages,代碼行數:27,代碼來源:HelpConfigDialog.cpp

示例12: initializeTFile

TFile* histfiles::initializeTFile(const char *processor_name, bool debug) {

  stringstream _name;
  _name << processor_name;
  if(_name.str()=="") _name.str("cafe"); 
  Config config(_name.str().c_str());
  string _output = config.get("Output", "result.root");

  if(debug) cout << "histfiles::initializeTFile:"
		 << " PROCESSOR_NAME=" << _name.str()
		 << " OUTPUT_FILE=" << _output
		 << endl;

  if (_output=="") return NULL;

  // keep track of rootuples that have been already created during this session 
  TFile *f = NULL;
  if (find(_histfiles_created.begin(),
	   _histfiles_created.end(),
	   _output) == _histfiles_created.end()) {
    
    if(debug) cout << "histfiles::initializeTFile: Output file has not been opened yet" << endl;
    f = new TFile(_output.c_str(),"RECREATE");
    if (f!=NULL) { 
      _histfiles_created.push_back(_output);
    }
  } else {
    if(debug) cout << "histfiles::initializeTFile: Output file has been already created" << endl;
    f = new TFile(_output.c_str(),"UPDATE");
  }
  return f; 
}
開發者ID:hengne,項目名稱:d0wmass,代碼行數:32,代碼來源:hist_files.cpp

示例13: release

    bool
    release(ObjectType*     theInstance)
    {
#if !defined(XALAN_NO_STD_NAMESPACE)
        using std::find;
#endif

        typedef typename VectorType::iterator   IteratorType;

        const IteratorType  i =
            find(
                m_busyList.begin(),
                m_busyList.end(),
                theInstance);

        if (i == m_busyList.end())
        {
            return false;
        }
        else
        {
            m_resetFunctor(theInstance);

            m_availableList.push_back(theInstance);

            m_busyList.erase(i);

            return true;
        }
    }
開發者ID:fpoltronieri,項目名稱:nomads,代碼行數:30,代碼來源:XalanObjectCache.hpp

示例14: operator

            auto operator()(const T & t, const C<T> & c) const {
                using std::find;

                auto found = find(c.begin(), c.end(), t);

                return found != c.end();
            }
開發者ID:Globidev,項目名稱:Fun-with-templates,代碼行數:7,代碼來源:elem.hpp

示例15: UpdateIndicies

        void UpdateIndicies(Device const& device)
        {
            vector<DWORD>& channelIndicies = m_channelsIndicies[device.DeviceID()];
            vector<string>const& channelStrings = m_channels[device.DeviceID()];
            channelIndicies.clear();

            // Create a list of strings from the device
            vector<string> sourceNames = device.GetChannelNames();

            vectorStringIter sourceBegin = sourceNames.begin();
            vectorStringIter sourceEnd = sourceNames.end();

            // do a search for each name
            for(vectorStringIter iter = channelStrings.begin();
                iter < channelStrings.end(); ++iter)
            {
                vectorStringIter item = find(sourceBegin, sourceEnd, *iter);
                if (item == sourceEnd)
                {
                    UCSBUtility::LogError("Data Aggregator config failure: "
                        "%s field does not exist in device %s", iter->c_str(), 
                        device.DisplayName().c_str());
                }
                else
                {
                    channelIndicies.push_back(item - sourceBegin);
                }
            }
        }
開發者ID:ucsbdeepspace,項目名稱:cofe-fts-flight-code-archive,代碼行數:29,代碼來源:Functionality.cpp


注:本文中的std::find方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。