Форум программистов, компьютерный форум CyberForum.ru

Оставить в слове первые вхождения каждой буквы - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Разложение sin(x) в ряд Тейлора http://www.cyberforum.ru/cpp-beginners/thread628046.html
Всем доброго время суток! Проверьте пожалуйста правильный ли следующий код : #include <cmath> #include <iostream> #include <cstdlib> using namespace std; double my_abs(double val) { double ret = val;
C++ Коварный map Доброго всем дня, уважаемые форумчане! Прошу прояснить следующий момент, почему при проходе по мапе теряется пара с ключом "4". Если флаг TExpiredNumberHandler стоит в true (на название класса прошу не обращать внимание): #include <iostream> #include <string> #include <map> #include <iterator> #include <utility> class TExpiredNumberHandler http://www.cyberforum.ru/cpp-beginners/thread628043.html
C++ Ошибка линкера
Здравствуйте!!! Подскажите пожалуйста почему возникают ошибки линкера? // main.cpp #include "parser.h" int main() { char prog_buff;
Как правильно организовать большой проект? C++
В будущем хочу участвовать в разработке игр - начал изучать С++, вопрос тут такой, как правильно организовать структуру достаточно большого проекта? в учебниках, с примерами в 1-2 файла все просто, но когда их становиться больше - я начинаю путатся. Например, пробую сделать примитивную 3Д модельку солнечной системы. есть некий базовый класс 3Д объекта, ответственный за перемещение и отрисовку...
C++ resize вектора векторов http://www.cyberforum.ru/cpp-beginners/thread627897.html
Необходимо удалить n элементов с конца вектора. В vector::erase необходимо передавать итератор. Т.к. итератора у меня нет, а есть конкретная цифра сколько нужно удалить, вродебы подходит функция vector::resize. Вопросы: 1. Если в векторе содержатся вектора, при использовании erase и resize они будут корректно удалены? Или произойдет утечка памяти? 2. Корректно ли использовать resize в моем...
C++ Не врубаюсь в работу деструктора Всем доброго времени суток. Не понимаю работу деструктора. Деструктор вроде как должен освобождать память от того что осталось после класса. Вот для примера код #include <iostream> using namespace std; class MyCl{ public: int mass; MyCl(); ~MyCl(); подробнее

Показать сообщение отдельно
-=ЮрА=-
Заблокирован
Автор FAQ
24.07.2012, 20:43     Оставить в слове первые вхождения каждой буквы
danwich, касательно 1-го моего вариант кода, да в нём кое-что было не так(всё потому что я пытаясь сделать код предельно понятным, кое-что заменил на глаз от и тестировал сжато) Поэтому вот код из поста 2 - он должен быть таким и никак иначе(настаиваю как автор)Изменения каснулись лишь адресации в char * getFirstAlphas(char * word)
(на скрине отработка программы для злобной саламандры которая позавтракала бедолагой страусом=))
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#include <string>
#include <sstream>
#include <iostream>
using namespace std;
 
//Функция возвратит слово лишь с 1-кратным вхождением букв
char * getFirstAlphas(char * word);
 
int main()
{
    system("chcp 1251");//Простая руссификация
    char text[1024] = {0};//Буффер для вводимого текста
    char word[32]   = {0};//Буффер для вводимого слова
    stringstream ss;//Стрингпоток (такой же поток ввода как ifstream
    //тольк очерпает он данные не из файла а с нашей строки)
    cout<<"Введите текст :\n";
    cin.getline(text,1023);//Вводим текст с пробелами
    ss.str(text);//Запихиваем наш текст в поток
    while(ss>>word)//Черпаем по слову из потока
        cout<<getFirstAlphas(word)<<" ";//и печатаем уже преобразованные слова
    cout<<endl;
    system("pause");//Стоп-точка
    return 0;
}
 
char * getFirstAlphas(char * word)
{
    char * sub= NULL;//Указатель на подстроку 
    char symbol=0;
    for(int i = 0; word[i] != '\0'; i++)
    {
        //Ищем 1-е вхождение символа в слово
        sub = strchr(word, (symbol = word[i]));
        //Поиск последующих вхождений указанного символа в строку
        while((sub = strchr(sub + 1, symbol)))
        {
            //Если повотрные вхождения есть
            //просто вытираем их из строки 
 
            //Проверяем не был ли символ последним в строке
            if(sub + 1)
                strcpy(sub, sub + 1);
            else//Если символ всё же был последним
            //обрезаем строку
                *sub = '\0';
        }
    }
    return word;//Возвращаем преобразованное слово
}
Миниатюры
Оставить в слове первые вхождения каждой буквы  
 
Текущее время: 13:47. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru