Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/13: Рейтинг темы: голосов - 13, средняя оценка - 4.62
0 / 0 / 0
Регистрация: 14.01.2019
Сообщений: 18

Найти в строке слово минимальной длины и возвратить индекс его начала

15.01.2019, 08:16. Показов 2802. Ответов 3

Студворк — интернет-сервис помощи студентам
Информатика 1 курс, прошу помочь с написанием программы:

Найти в строке слово минимальной длины и возвратить индекс его начала.

у меня есть нерабочий код:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
int f(char B [])
{
    int curi = 0, curn = 0, count = 0; int A[128];
    while (B[curi - 1] != 0)
        {
 
        if (isalnum(B[curi]))
            curn++;
        elseif (curn> 0)
        {
            A[curi - curn] = curn;
            count++;
            curn = 0;
        }
        curi++;
    }
    int min = A[0];
    for (int i = 0; i<curi; i++)
    if (A[i] < min && A[i]>0)
        min = A[i]-1;
    return min;
}
заранее благодарю.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.01.2019, 08:16
Ответы с готовыми решениями:

Найти слово, начинающееся с самой младшей латинской буквы и возвратить индекс его начала
Дана строка, содержащая некоторый текст (включая пробелы и знаки препинания). Под словом понимается набор символов, не содержащий пробелов...

Найти в строке два одинаковых фрагмента длиной более 5 символов и возвратить индекс начала первого из них
Всем добрый вечер. Собственно нужна ваша помощь, есть условие: &quot;Найти в строке два одинаковых фрагмента (не включающих в себя...

В каждой строке найти слово минимальной длины
у меня дан код программы не могу его дописать на С задача такова даны строки в каждой строке нужно найти минимальное слово длиной и...

3
11 / 14 / 12
Регистрация: 20.03.2017
Сообщений: 182
15.01.2019, 09:10
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
#include <string>
#include <iostream> 
#include <sstream>
 
using namespace std;
 
int main() 
{ 
    string text; // строка с текстом
    cout << "Enter a text:\n";
    getline(cin, text); // считываем в переменную text
    istringstream is(text); // создаем поток с из переменной text
    string max_word; // слово максимальной длины
    is >> max_word; // считываем первое слово
 
    string current;
    while(is >> current) // считываем остальные слова
    {
        if (current.size() > max_word.size()) // сравниваем длины, и меняем если нужно
            max_word = current;
    }
 
    cout << "word: " << max_word << '\n';
    return 0; 
}
0
Параллельный Кот
 Аватар для valen10
1905 / 827 / 350
Регистрация: 25.03.2016
Сообщений: 2,045
15.01.2019, 13:07
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
50
51
52
53
54
55
56
57
#include <iostream>
#include <string>
using namespace std;
 
size_t findMinWord(const char *str) {
    size_t min_pos = string::npos;
    size_t min_length = 0;
 
    size_t pos = 0;
    // Пока не будет достигнут конец строки.
    while (str[pos]) {
        // Поиск начала слова: первый символ, отличный от пробела.
        while (str[pos] == ' ') {
            pos++;
        }
 
        size_t length = 0;
        // Поиск конца слова: конец строки или пробел.
        while (str[pos + length] && (str[pos + length] != ' ')) {
            length++;
        }
 
        // Обновить информацию, если это первое слово в строке
        // или сейчас было найдено более короткое слово.
        if ((min_pos == string::npos) || (length && (length < min_length))) {
            min_pos = pos;
            min_length = length;
        }
 
        // Передвинуть позицию правее конца текущего слова.
        pos += length;
    }
 
    return min_pos;
}
 
int main() {
    string str;
    getline(cin, str);
 
    size_t pos = findMinWord(str.c_str());
    if (pos != string::npos) {
        cout << "Index: " << pos << endl;
 
        // Вывод найденного слова для наглядности.
        cout << "Word: ";
        while (str[pos] && (str[pos] != ' ')) {
            cout << str[pos++];
        }
        cout << endl;
    }
    else {
        cout << "String is empty." << endl;
    }
 
    return 0;
}
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
16.01.2019, 02:34
Цитата Сообщение от Екатерина1831 Посмотреть сообщение
Найти в строке слово минимальной длины и возвратить индекс его начала.
Найти в строке первое слово минимальной длины и возвратить индекс его начала.

словом будем считать последовательность символов, отделённую одним или несколькими пробелами
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
#include <iostream> 
#include <string> 
#include <sstream> 
using namespace std;
 
size_t IndexMinWord (string s)
{
    string word, min_word;    
    size_t min=s.size(), index;
    
    stringstream words(s), words1(s);
    while (words >> word) 
    {
        if (word.size()<min) min=word.size();        
    }    
    
    while (words1 >> word) 
    {
        if (word.size()==min) {min_word=word;break;}        
    } 
    s=" "+s+" ";
    cout <<min_word<<"\n";
    index=s.find(" "+min_word+" ");    
    
    return index;
}    
 
int main() 
{    
    string s;
    cout << "String:\n";
    getline(cin, s);
    
    cout <<IndexMinWord (s)<<"\n";
system("pause");
return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.01.2019, 02:34
Помогаю со студенческими работами здесь

В тексте найти слово минимальной длины и удвоить его дублированием букв
Пока что смог написать только нахождение длинны минимального слова. Если например через Split найти минимальное слово, там его...

Строка: Поменять в данной строке второе слово и слово минимальной длины...
Поменять в данной строке второе слово и слово минимальной длинны (первое по порядку)

Поменять в данной строке третье слово и слово минимальной длины
Поменять в данной строке третье слово и слово минимальной длины (первое по порядку).

Поменять в данной строке предпоследнее слово и слово минимальной длины (первое по порядку)
Поменять в данной строке предпоследнее слово и слово минимальной длины (первое по порядку).

Определить в строке слово (или слова) минимальной длины
1)Дана матрица А размерностью n*n. Найти скалярное произведении строки в котором находиться максимальный элемент матрицы на столбец с...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru