Найти все вхождения и местоположения подстроки - PullRequest
21 голосов
/ 27 октября 2010

Я пишу программу для анализа некоторых данных, сохраненных в виде текстовых файлов. Я пытаюсь найти местоположение каждой иголки в стоге сена. Я уже могу прочитать файл и определить количество вхождений, но я ищу также и индекс.

Ответы [ 2 ]

27 голосов
/ 27 октября 2010
string str,sub; // str is string to search, sub is the substring to search for

vector<size_t> positions; // holds all the positions that sub occurs within str

size_t pos = str.find(sub, 0);
while(pos != string::npos)
{
    positions.push_back(pos);
    pos = str.find(sub,pos+1);
}

Редактировать Я неправильно прочитал ваш пост, вы сказали подстроку, и я предположил, что вы имели в виду, что вы ищете строку.Это все равно будет работать, если вы прочитаете файл в строку.

6 голосов
/ 27 октября 2010

Я знаю, что ответ принят, но это также сработает и избавит вас от необходимости загружать файл в строку.

#include <iostream>
#include <fstream>
#include <vector>
#include <algorithm>

using namespace std;

int main(void)
{
  const char foo[] = "foo";
  const size_t s_len = sizeof(foo) - 1; // ignore \0
  char block[s_len] = {0};

  ifstream f_in(<some file>);

  vector<size_t> f_pos;

  while(f_in.good())
  {
    fill(block, block + s_len, 0); // pedantic I guess..
    size_t cpos = f_in.tellg();
    // Get block by block..
    f_in.read(block, s_len);
    if (equal(block, block + s_len, foo))
    {
      f_pos.push_back(cpos);
    }
    else
    {
      f_in.seekg(cpos + 1); // rewind
    }
  }
}
...