문자열 반복: 우아함과 효율성의 만남
특히 공백으로 구분된 경우 문자열의 개별 단어를 반복하는 것은 일반적인 프로그래밍입니다. 일. 다양한 접근 방식이 존재하지만 우아하고 효율적인 솔루션을 찾는 것은 어려울 수 있습니다.
StringStream을 사용하는 현재 방법
제공된 예는 문자열 스트림을 활용하지만 OP는 더 많은 접근 방식을 추구합니다. 우아한 솔루션. 이 방법은 확실히 강력하지만 일부 문자 조작이 필요하며 원하는 만큼 간결하지 않습니다.
우아한 솔루션: 문자열 분할
우아함과 효율성을 모두 달성하려면 C의 Split() 함수를 활용할 수 있습니다. 이 함수는 문자열과 구분 기호를 입력으로 사용하고 분할된 단어가 포함된 벡터를 반환합니다.
#include <vector> #include <string> template <typename Out> void split(const std::string &s, char delim, Out result) { std::istringstream iss(s); std::string item; while (std::getline(iss, item, delim)) { *result++ = item; } } std::vector<std::string> split(const std::string &s, char delim) { std::vector<std::string> elems; split(s, delim, std::back_inserter(elems)); return elems; }
이 솔루션에는 최소한의 코드가 필요하며 이해하기 쉽습니다. 이는 단순히 문자열을 문자열 스트림으로 읽고 getline() 함수를 사용하여 지정된 구분 기호를 사용하여 개별 단어를 추출합니다. 그런 다음 추가 처리를 위해 분할된 문자열을 벡터에 저장할 수 있습니다.
그러나 이 솔루션은 빈 토큰을 건너뛰지 않는다는 점을 명심하세요. 빈 문자열을 제거해야 하는 경우 벡터를 추가로 후처리할 수 있습니다.
위 내용은 문자열의 단어를 어떻게 효율적이고 우아하게 반복할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!