Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Удаление слов из сиимвольной строки, Удаление слов 
:(
    Опции темы
Weman
Дата 27.2.2006, 22:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 133
Регистрация: 29.11.2005
Где: Санкт-Петрбург

Репутация: нет
Всего: нет



Помогите с задачей:
В символьной строке удалить все слова, начинающиеся и заканчивающиеся на одну и ту же букву.

Сделать надо с помощью указателей!
Код приводите пожалуйста на Си в форме для "чайников" smile(с пояснениями)
Спасибо
--------------------
PM MAIL ICQ   Вверх
MAKCim
Дата 28.2.2006, 08:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Воін дZэна
****


Профиль
Группа: Экс. модератор
Сообщений: 5644
Регистрация: 10.12.2005
Где: Менск, РБ

Репутация: 52
Всего: 207



Код

void resize(char* str)
{
    int size=length(str), j=0,k;
    char temp;
    const char space=' ';
    while (*str)
    {
        if (*str!=space)
        {
            if (!j || *(str-1)==space) temp=*str, k=j;
            else if (j+1==size || *(str+1)==space)
            {
                if (*str==temp)
                {
                    /*удаляем слово str[j]...str[k]*/
                }
            }
        }
        j++;
    }
}


Это сообщение отредактировал(а) MAKCim - 28.2.2006, 08:30


--------------------
Ах, у елі, ах, у ёлкі, ах, у елі злыя волкі ©

PM MAIL   Вверх
Dov
Дата 28.2.2006, 15:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

Репутация: 15
Всего: 88



Код
void main()
{
    char  str[] = "mama myla ramu mylom";
    char* delim = ".,:; ?!-()[]{}";    // разделители слов 

    cout << "Before: " << str << "\nAfter : "; 

    char *p = strtok(str, delim);      // выделяем слово в строке

    while(p)                           // пока есть слова
    {
        if(*p != *(p + strlen(p) - 1)) // если 1-й и последний символ не совпадают
            cout << p << ' ';               // печатаем слово(можно занести в массив, 
                                               // а потом вывести на экран)
        p = strtok(NULL, delim);       // выделяем следующее слово
    }

    cout << endl;
}



--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
Weman
Дата 1.3.2006, 20:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 133
Регистрация: 29.11.2005
Где: Санкт-Петрбург

Репутация: нет
Всего: нет



Dov, Не мог бы ты написать свой код на Си?
--------------------
PM MAIL ICQ   Вверх
Dov
Дата 1.3.2006, 21:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

Репутация: 15
Всего: 88



Код
#include <stdio.h>
#include <string.h>

int main()    
{    
    char  str[] = "11'310gjsh3'Hel""lo,521gghfgf5 wo""rld.sg22s'gfh01sg'";    
    char* delim = ".,:; ?!-()[]{}`'~";  // разделители слов 
    
    printf("Before: %s\nAfter : ", str); 
    
    char *p = strtok(str, delim);      // выделяем слово в строке    
    while(p)                           // пока есть слова    
    {    
        if(*p != *(p + strlen(p) - 1)) // если 1-й и последний символ не совпадают    
            printf("%s ", p);               // печатаем слово(можно занести в массив,    
                                               // а потом вывести на экран)    
        p = strtok(NULL, delim);       // выделяем следующее слово    
    }
    
    putchar('\n');

    return 0;
}



--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
Weman
Дата 2.3.2006, 13:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 133
Регистрация: 29.11.2005
Где: Санкт-Петрбург

Репутация: нет
Всего: нет



Расскажите пожалуйста про функцию strtok(). В книге почитал про нее, ничего не понял (было очень мудрено написано).
Опишите ее принцип работы на языке "новичка в программировании" smile
--------------------
PM MAIL ICQ   Вверх
_hunter
Дата 2.3.2006, 14:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник Клуба
Сообщений: 8564
Регистрация: 24.6.2003
Где: Europe::Ukraine:: Kiev

Репутация: 16
Всего: 98



что значит "очень мудрено"?
находит следующее вхождение в строке это мудрено?
и что значит "принцип работы"? -- исходник поищи...



--------------------
Tempora mutantur, et nos mutamur in illis...
PM ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0717 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.