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

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

Войти
Регистрация
Восстановить пароль
 
kuwmen
0 / 0 / 0
Регистрация: 23.10.2011
Сообщений: 23
#1

В тексте найти и вывести слово наибольшей длины, в котором нет заданной буквы - C++

26.10.2011, 14:59. Просмотров 651. Ответов 2
Метки нет (Все метки)

Помогите пожалуйста. Дуб дубом, а завтра сдавать надо.
Надо на писать на простом си, желательно с парой комментариев(
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.10.2011, 14:59     В тексте найти и вывести слово наибольшей длины, в котором нет заданной буквы
Посмотрите здесь:

Найти в тексте самое длинное слово в котором нет цифр - C++
Найти в тексте самое длинное слово в котором нет цифр. Пожалуйста, очень надо)

Дан текстовый файл. Вывести первое слово текста наибольшей длины - C++
Такое слово должно выводиться с учетом знаков препинания, расположенных в начале и в конце слова. Помогите пожалуйста!:)

Дан текстовый файл. Вывести первое слово текста наибольшей длины - C++
Дан текстовый файл.Вывести первое слово текста наибольшей длины.помогите написать прогу на си

Исправить ошибку. Программа находит в введенном тексте слово, в котором буквы идут по алфавиту - C++
Программа находит в введенном тексте слово, в котором буквы идут по алфавиту и выводит его на экран. Написала программу, но она работает...

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

Найти самое длинное слово начинающееся с заданной буквы - C++
Дана строка символов. Найти самое длинное слово, начинающееся с буквы ''я'', и вывести его в обратном порядке. С++ рабочая программа...

В словах наибольшей длины удалить среднюю букву (средние буквы) - C++
В тексте все слова разделены пробелами и знаками препинания. Напечатать все слова, предварительно выполнив преобразования: в словах...

В тексте найти и вывести слово в кавычках - C++
Доброго дня!Допоможіть з завданням на мові С++!буду вдячний """У введеному тескті знайти і вивести слова у лапках""" Текст можна будь...

Сформировать предложение из слов заданной длины, в которых нет перевернутой заданной подстроки, но есть сама - C++
Дан массив слов и подстрока. Сформировать предложение из слов заданной длины, в которых нет перевернутой заданной подстроки, но есть сама...

Подскажите как найти слово строке в котором больше 2 букв 'a', а затем вывести его?Без использования string - C++
Подскажите как найти слово строке в котором больше ОДНОЙ буквы 'a', а затем вывести его?Без string.


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
easybudda
Эксперт CЭксперт С++
9461 / 5474 / 927
Регистрация: 25.07.2009
Сообщений: 10,496
26.10.2011, 16:24     В тексте найти и вывести слово наибольшей длины, в котором нет заданной буквы #2
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
#include <stdio.h>
#include <string.h>
    
#define STR_LEN 1024
#define STR_MASK "%1023[^\n]%*c"
#define CHAR_MASK "\t%c%*c"
#define DELIM " ,.!?;:\t"
    
int main(void){
    char str[STR_LEN], * pWord, * pMaxWord, ch;
    int iCurLen, iMaxLen;
    
    while ( printf("String: ") && scanf(STR_MASK, str) == 1 && printf("Exclude char: ") && scanf(CHAR_MASK, &ch) == 1 ){
        iMaxLen = 0;
        pMaxWord = NULL;
        
        for ( pWord = strtok(str, DELIM); pWord; pWord = strtok(NULL, DELIM) ){
            if ( ! strchr(pWord, ch) ){
                if ( ( iCurLen = strlen(pWord) ) > iMaxLen ){
                    iMaxLen = iCurLen;
                    pMaxWord = pWord;
                }
            }
        }
        if ( iMaxLen == 0 )
            printf("No words without letter %c\n", ch);
        else
            printf("The first max length (%d) word without letter %c is %s\n", iMaxLen, ch, pMaxWord);      
    }
    
    return 0;
}
kuwmen
0 / 0 / 0
Регистрация: 23.10.2011
Сообщений: 23
09.11.2011, 14:52  [ТС]     В тексте найти и вывести слово наибольшей длины, в котором нет заданной буквы #3
Цитата Сообщение от easybudda Посмотреть сообщение
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
#include <stdio.h>
#include <string.h>
    
#define STR_LEN 1024
#define STR_MASK "%1023[^\n]%*c"
#define CHAR_MASK "\t%c%*c"
#define DELIM " ,.!?;:\t"
    
int main(void){
    char str[STR_LEN], * pWord, * pMaxWord, ch;
    int iCurLen, iMaxLen;
    
    while ( printf("String: ") && scanf(STR_MASK, str) == 1 && printf("Exclude char: ") && scanf(CHAR_MASK, &ch) == 1 ){
        iMaxLen = 0;
        pMaxWord = NULL;
        
        for ( pWord = strtok(str, DELIM); pWord; pWord = strtok(NULL, DELIM) ){
            if ( ! strchr(pWord, ch) ){
                if ( ( iCurLen = strlen(pWord) ) > iMaxLen ){
                    iMaxLen = iCurLen;
                    pMaxWord = pWord;
                }
            }
        }
        if ( iMaxLen == 0 )
            printf("No words without letter %c\n", ch);
        else
            printf("The first max length (%d) word without letter %c is %s\n", iMaxLen, ch, pMaxWord);      
    }
    
    return 0;
}
Не мог бы кто-нибудь помочь переписать программу, чтобы она была выполнена с помощью функции?
Ответ Создать тему
Опции темы

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