범위 기반 For 루프에서 요소 위치 찾기
프로그래밍에서는 반복되는 요소의 인덱스나 위치를 결정해야 하는 경우가 많습니다. 위에. 컨테이너를 반복하는 편리한 방법을 제공하는 범위 기반 for 루프를 사용할 때 별도의 반복자를 사용하지 않고 현재 요소의 인덱스를 검색하는 것이 가능한지 의문이 생깁니다.
해결책
1. 지퍼 기술
한 가지 방법은 지퍼링이라는 기술을 사용하는 것입니다. 여기에는 도중에 컨테이너와 인덱스를 결합하여 각 쌍이 인덱스와 해당 요소로 구성된 새로운 쌍 범위를 생성하는 작업이 포함됩니다.
struct Indexer { class iterator { iterator(typename T::iterator it): _pos(0), _it(it) {} std::pair<size_t, typename T::reference> operator*() const { return std::make_pair(_pos, *_it); } // ... }; iterator begin() const { return iterator(_container.begin()); } iterator end() const { return iterator(_container.end()); } private: T& _container; };
Indexer 클래스를 사용하면 반복이 가능해집니다. 컨테이너를 통해 인덱스와 요소를 동시에 가져옵니다.
2. Boost.Range
또 다른 옵션은 Boost.Range 라이브러리를 활용하는 것입니다. 특히, Boost::adaptors::indexed 어댑터를 사용하여 각 반복에 대한 인덱스와 요소를 모두 포함하는 파생 범위를 생성할 수 있습니다.
std::vector<int> v{1, 2, 3, 4, 5, 6, 7, 8, 9}; for (auto const& [idx, elem]: boost::adaptors::indexed(v)) { std::cout << idx << ": " << elem << "\n"; }
부스트에서 얻은 결과 범위를 반복하여 다음을 수행합니다. :adaptors::indexed, for 루프 내에서 인덱스와 요소에 액세스할 수 있습니다.
3. 사용자 정의 반복기
특정 시나리오에서는 현재 인덱스를 유지하는 사용자 정의 반복기를 생성하는 것이 바람직할 수 있습니다. 이 반복자는 범위 기반 for 루프와 함께 사용하여 인덱스와 요소 모두에 액세스할 수 있습니다.
class IndexedIterator { private: container_type* _container; size_t _index; public: IndexedIterator(container_type* c) : _container(c), _index(0) {} bool operator!=(const IndexedIterator& other) const { return _container != other._container || _index != other._index; } std::pair<size_t, value_type> operator*() const { return std::make_pair(_index, *_container[_index]); } IndexedIterator& operator++() { _index++; return *this; } };
사용자 정의 반복자를 정의하고 이를 컨테이너의 반복자 유형에 적용하면 다음을 얻을 수 있습니다. for 루프 내에서 직접 요소와 해당 인덱스.
위 내용은 C 범위 기반 For 루프에서 요소 인덱스를 어떻게 얻을 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!