Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 21.05.2014
Сообщений: 36
1

Быстрый сплит

12.11.2014, 16:54. Показов 564. Ответов 2
Метки нет (Все метки)

Помогите пожалуйста найти самый быстрый способ преобразования строки в массив подстрок по некоторому символу (в частности, по пробелу)
Я пробовал использовать 4 способа, но все они работают медленнее, чем *.Split(' ') в C#
1:
C++
1
2
3
        typedef vector < string > splitted_vector_type;
        splitted_vector_type split_vec;
        split(split_vec, buf, std::bind2nd(std::equal_to<char>(), ' '));
из библиотеки boost

2:
C++
1
2
3
4
5
6
7
8
        istringstream ist(buf);
        ist >> Var1;
        ist >> Var2;
        ist >> Var3;
        ist >> Var4;
        ist >> Var5;
        ist >> Var6;
        ist >> Var7;
3:
C++
1
2
3
4
5
6
7
8
        char *Delimiters = " ";
        Var1 = strtok(NULL,Delimiters );
        Var2 = strtok(NULL,Delimiters );
        Var3 = strtok(NULL,Delimiters );
        Var4 = strtok(NULL,Delimiters );
        Var5 = strtok(NULL,Delimiters );
        Var6 = strtok(NULL,Delimiters );
        Var7 = strtok(NULL,Delimiters );
4:
посимвольно перебираю строку и получаю подстроки и записываю к соответствующим переменным


Все они работают медленнее чем в C#. (наверное уже догадались что у мне считать 7 значений)


Надеюсь проблема не в методе получения строк из файла, здесь используется следующий способ
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include "stdafx.h"
#include <iostream>
using namespace std;
 
int _tmain(int argc, _TCHAR* argv[])
{
    const int LENGTH = 256;
    FILE *in;
    char buf[LENGTH]=" ";
    char per[15];
    fopen_s(&in, "D:\\1.txt","rb");
    fgets(buf, LENGTH, in);
    int i;
    while (!feof(in))
    {
        fgets(buf, LENGTH, in);
 
        \\   здесь функция сплитования строки buf
 
    }
    fclose(in);
    return 0;
}
__________________
Помощь в написании контрольных, курсовых и дипломных работ здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
12.11.2014, 16:54
Ответы с готовыми решениями:

Быстрый почтальон
Привет всем. Eсли сможете напишите код программы &quot;Быстрый почтальон&quot; на я.п. С\С++ Почтальону...

Быстрый аллокатор
Собственно, необходим аллокатор для быстрого выделения памяти под мелкие объекты, совместимый со...

быстрый xor
Нужно про-xor-ить биты в числе. Можно ли это сделать быстрее, чем u_char r = 0; for (i = 0; i &lt;...

Быстрый поиск
Здравствуйте. Нужно выполнить поиск i-го вхождения заданного элемента в исходном наборе чисел....

2
19 / 18 / 1
Регистрация: 06.09.2012
Сообщений: 110
12.11.2014, 19:05 2
Возможно вам это как то поможет:

C
1
2
3
4
5
6
7
8
9
10
11
char text[100] = { "Test*1337*LOL" };
    char * a[1024];
    char * t = strtok(text, "*");
    int i; int portint;
    for (i = 0; t; t = strtok(NULL, "*"), i++)
    {
        a[i] = t;
    }
    cout << a[0] << "\n";
    cout << a[1] << "\n";
    cout << a[2] << "\n";
0
0 / 0 / 0
Регистрация: 21.05.2014
Сообщений: 36
13.11.2014, 11:10  [ТС] 3
Спасибо, работает на много быстрее, но теперь у меня другая проблема
C# работает быстрее чем С++
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
13.11.2014, 11:10

Быстрый Вопрос
У меня один короткий вопрос. Как найти все цифры числа ? Т.е. 12345 число. 1 2 3 4 5 цифры.

Быстрый вызов
Как програмно сделать так что бы при нажатии сочетания клавиш F12+Home запускалась программа из...

Быстрый ввод и вывод
Добрый день. Прошу прощения за нубский вопрос, но все-таки... Хотелось бы узнать у гуру, какие...

Быстрый парсинг строки
Всем доброго времени суток... Прошу разъяснить что делаю не так. Получаю строку вида, нужно ее...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.