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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
2009
2 / 2 / 0
Регистрация: 23.11.2009
Сообщений: 35
#1

Строки - C++

14.06.2010, 18:41. Просмотров 367. Ответов 3
Метки нет (Все метки)

Всем привет! Завтра у меня зачет по программированию и мне нужно решить 3 задачи на тему строки. Помогите пожалуйста:
1) Дано предложение. Найти самое короткое слово нечетной длины.
2) Дано предложение. Подсчитать количество слов-перевертышей.
3) Дано предложение. В словах четной длины удалить каждую вторую букву.
P.S. Писать на turbo c++ и желательно чтоб было понятно для первокурсника. Заранее благодарен.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.06.2010, 18:41     Строки
Посмотрите здесь:

Упорядочить строки массива в соответствии с ростом характеристики строки C++
C++ как сделать из строки массив из символов этой строки
C++ Рассортировать строки динамической матрицы по наибольшему элементу строки.
C++ Отсортировать цифры, символы и буквы из строки в отдельные строки
C++ Строки в файлах (вывести из каждой строки последнее слово)
Строки (Расположить слова строки в порядке, обратном исходному) C++
C++ Структуры и строки (как поменять значение строки в структуре?)
C++ Вводятся 2 строки. Перевернуть обе строки, склеить и вывести
C++ Даны строки s, s0. Найти количество вхождений строки s0 в строку s
C++ Разместить текст первой строки по центру второй строки
Считать строки из файла, найти строки на определённую букву C++
C++ Получение переменных из строки, изменение строки, запись в файл

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
.::.DIMA.::.
142 / 142 / 4
Регистрация: 26.10.2008
Сообщений: 782
14.06.2010, 19:05     Строки #2
Используя функцию strtok, разбивайте предложения на слова, а дальше с каждым словом делайте что требуется в задаче.
2009
2 / 2 / 0
Регистрация: 23.11.2009
Сообщений: 35
14.06.2010, 21:41  [ТС]     Строки #3
а поподробнее можно?

Добавлено через 2 часа 1 минуту
объясните пожалуйста а то я не понимаю
.::.DIMA.::.
142 / 142 / 4
Регистрация: 26.10.2008
Сообщений: 782
14.06.2010, 22:22     Строки #4
Вот решение первой задачи:
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
#include <iostream>
using namespace std;
 
int main()
{
    const int n = 300;
    char * str = new char [n];  
    char * word = new char [n];
    char seps [] = " \t\n,.";
    char * token;
 
    cin.getline(str, n);
 
    int minlen = 0;
    int tmp;
    token = strtok(str, seps);
    minlen = strlen(token);
    if (minlen % 2 == 0)
        minlen = 0;
    strcpy(word, token);
    while (token != NULL)
    {
        tmp = strlen(token);
        if (minlen == 0 && tmp % 2 != 0)
            minlen = tmp;
        if (tmp % 2 != 0 && tmp <= minlen)
            strcpy(word, token);
        token = strtok(NULL, seps);
    }
    cout << word << endl;
 
    delete [] str;
    delete [] word;
    return 0;
}
Функция strtok разделяет строку, переданную ей в качестве первого аргумента, элементами, наодящимися в строке, переданной в качестве второго аргумента. Т.е. в цикле каждый раз получаем отдельное слово. С этим словом можно работать как с отдельной строкой.
Аналогичным образом решаются все ваши задачи.
Yandex
Объявления
14.06.2010, 22:22     Строки
Ответ Создать тему
Опции темы

Текущее время: 11:19. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru