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

std::lenth_error, конкатенация картинок

18.11.2021, 22:40. Показов 768. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер ! Отладчик выдает сообщение "std::lenth_error" и показывает на 52ую строку программы. Функции взяты из книги (я только дописал main). Причем раньше "окаймление рамкой"- тоже была отдельная функция и она выдавала точно такую же ошибку, затем я расформировал её и включил в main- всё заработало и я не стал заморачиваться над причиной. Потом я добавил функцию hcat, но с ней такой "фокус" не проходит почему-то (да и неправильно это наверно, я ведь все таки хочу чтоб это была отдельная функция).
Если вводить короткие строки- то все нормально, но если ввести 3 строки где-то по 40-50 символов, но все рушится. Не пойму в чем тут дело и try-catch не помогает (по идее он должен вывести код ошибки- но там просто число из 8 где-то цифр которое не гуглится). Подскажите пожалуйста, вот код :
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include <iostream>
#include <algorithm>
#include <iomanip>
#include <ios>
#include <stdlib.h>
#include <stdio.h>
#include <stdexcept>
#include <string>
#include <vector>
#include <io.h>
#include <list>
#include <fcntl.h>
#include <Windows.h>
#include <fstream>
using namespace std;
 
///////////////////////Нахождение самого длинного слова///////////////
string::size_type width(const vector<string>& v) {
    try {
        string::size_type maxlan = 0;
        for (vector<string>::size_type i = 0; i != v.size(); ++i) {
            maxlan = max(maxlan, v[i].size());
            return maxlan;
        }
    }
    catch (domain_error e) {
        cout << e.what() << std::endl;
    }
}
 
/////////////////////горизонтальная конкатенация/////////////////
vector<string> hcat(const vector<string>& left,
    const vector<string>& right) {
    try {
        vector<string> ret;
        // Добавляем 1, чтобы оставить пробел между картинками.
        string::size_type width1 = width(left) + 1;
        // используем индексы для просмотра элементов из
        // векторов left right cooTBeTcTBeHHo.
        vector<string>::size_type i = 0, j = 0;
        // Продолжаем обработку до тех пор, пока не увидим
        // все строки из обеих исходных картинок.
        while (i != left.size() || j != right.size()) {
            // Coздаем новый string-o6ъекта для хранения
            // символов из обеих исходных картинок.
            string s;
            // Копируем строку из левой картинки, если
            // таковая существует.
            if (i != left.size())
                s = left[i++];
            // Дополняем объект s пробелами до максимальной ширины.
            s += string(width1 - s.size(),' ');
            // копируем строку из правой картинки, если таковая существует.
            if (j != right.size())
                s += right[j++];
            // Добавляем string-oъект в новую картинку.
            ret.push_back(s);
        }
        return ret;
    }
    catch (domain_error e) {
        cout << e.what() << std::endl;
    }
}
 
    int main()
    {
        try {       
            vector<string> slova;
            vector<string> ramka;
            string x;
            string::size_type maximum = 0;            
            while (cin >> x) {
                slova.push_back(x);
            }
            ///////Окаймление рамкой/////////
            for (vector<string>::size_type i = 0; i != slova.size(); ++i) {
                maximum = max(maximum, slova[i].size());
            }
            string border(maximum + 4, '*');
            ramka.push_back(border);
            for (vector<string>::size_type i = 0; i != slova.size(); ++i) {
                ramka.push_back("* " + slova[i] + string(maximum - slova[i].size(), ' ') + " *");
            }
            ramka.push_back(border);
 
            vector<string> now;
            now= hcat(slova, ramka);
            for (vector<string>::size_type i = 0; i != now.size(); ++i) {
                cout << now[i] << '\n';
            }            
        }
        catch (domain_error e) {
            cout << e.what() << std::endl;
        }
    }
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.11.2021, 22:40
Ответы с готовыми решениями:

Не воспринимает ни std::cout, ни std::cin. Вобщем ничего из std. Также не понимает iostream
Здравствуйте! Я хотел начать изучать язык C++. Набрал литературы. Установил Microsoft Visual C++ 2005 Express Edition. Образ диска...

ошибка error: cannot convert 'std::string {aka std::basic_string<char>}' to 'std::string* {aka std::basic_stri
на вод поступают 2 строки типа string. определить количество вхождений строки 2 в строку 1 ошибка error: cannot convert 'std::string {aka...

STL std::set, std::pair, std::make_pair
Я не знаю как описать тему в двух словах, поэтому не обращайте внимание на название темы. Собственно перейдем к нашим баранам: есть...

2
Эксперт С++
 Аватар для hoggy
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
19.11.2021, 00:07
Лучший ответ Сообщение было отмечено Роман888 как решение

Решение

Цитата Сообщение от Роман888 Посмотреть сообщение
Подскажите пожалуйста
у тебя в коде множество ошибок.
фатальной оказалась ошибка в логике.

часть ошибок я исправил.
ошибку в логике исправь сам.

https://rextester.com/MVETD41381

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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#include <stdexcept>
#include <iostream>
#include <string>
#include <vector>
using namespace std;
 
///////////////////////Нахождение самого длинного слова///////////////
string::size_type width(const vector<string>& v) {
    try {
        string::size_type maxlan = 0;
        for (vector<string>::size_type i = 0; i != v.size(); ++i) {
            maxlan = max(maxlan, v[i].size());
            return maxlan;
        }
    }
    catch (const exception& e) {
        cout << e.what() << std::endl;
    }
    return std::string::npos;
}
 
/////////////////////горизонтальная конкатенация/////////////////
vector<string> hcat(const vector<string>& left,
    const vector<string>& right) {
    try {
        vector<string> ret;
        // Добавляем 1, чтобы оставить пробел между картинками.
        string::size_type width1 = width(left) + 1;
        // используем индексы для просмотра элементов из
        // векторов left right cooTBeTcTBeHHo.
        vector<string>::size_type i = 0, j = 0;
        // Продолжаем обработку до тех пор, пока не увидим
        // все строки из обеих исходных картинок.
        while (i != left.size() || j != right.size()) {
            // Coздаем новый string-o6ъекта для хранения
            // символов из обеих исходных картинок.
            string s;
            // Копируем строку из левой картинки, если
            // таковая существует.
            if (i != left.size())
                s = left[i++];
            cout << "width1 = " << width1 << ", s.size = " << s.size() << '\n';
            if(width1 < s.size())
                throw logic_error("**** off and die");
            // Дополняем объект s пробелами до максимальной ширины.
            s += string(width1 - s.size(),' ');
            // копируем строку из правой картинки, если таковая существует.
            if (j != right.size())
                s += right[j++];
            // Добавляем string-oъект в новую картинку.
            ret.push_back(s);
        }
        return ret;
    }
    catch (const exception& e) {
        cerr << e.what() << std::endl;
    }
    return {};
}
 
    int main()
    {
        try {       
            vector<string> slova;
            vector<string> ramka;
            string x;
            string::size_type maximum = 0;            
            while (cin >> x) {
                slova.push_back(x);
            }
            ///////Окаймление рамкой/////////
            for (vector<string>::size_type i = 0; i != slova.size(); ++i) {
                maximum = max(maximum, slova[i].size());
            }
            string border(maximum + 4, '*');
            ramka.push_back(border);
            for (vector<string>::size_type i = 0; i != slova.size(); ++i) {
                const size_t len = maximum - slova[i].size();
                const string tmp(len, ' ');
                ramka.push_back("* " + slova[i] + tmp + " *");
            }
            ramka.push_back(border);
 
            vector<string> now;
            now= hcat(slova, ramka);
            for (vector<string>::size_type i = 0; i != now.size(); ++i) {
                cout << now[i] << '\n';
            }            
        }
        catch (const exception& e) {
            cerr << e.what() << std::endl;
        }
    }
1
0 / 0 / 0
Регистрация: 15.11.2021
Сообщений: 5
19.11.2021, 16:53  [ТС]
Большое спасибо ! Исправил. У меня return находился внутри цикла, из-за этого функция width работала не так, как задумано. И еще я думал что алгоритм max находится в заголовке <algorithm>, похоже, что это не так.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.11.2021, 16:53
Помогаю со студенческими работами здесь

На основе исходного std::vector<std::string> содержащего числа, создать std::vector<int> с этими же числами
подскажите есть вот такая задача. Есть список . Создать второй список, в котором будут все эти же числа, но не в виде строк, а в виде...

Std::begin() ,std::end(),std::copy
...// int main() { std::vector&lt;double&gt; data;//Работает cout &lt;&lt; std::begin(data); double *data=new double; ...

Std::bind, std::mem_fun, std::mem_fn
В чем разница между функциями std::bind, std::mem_fun, std::mem_fn?

std::pair<std::list<std::pair< >>::iterator, > ломается при возврате из функции
#include &lt;iostream&gt; #include &lt;list&gt; #include &lt;string&gt; #include &lt;utility&gt; using lp = std::list&lt;std::pair&lt;std::string, int&gt;&gt;; ...

(std::basic_string<char, std::char_traits<char>, std::allocator<char> > const&
astxx::manager::connection::connection(std::basic_string&lt;char, std::char_traits&lt;char&gt;, std::allocator&lt;char&gt; &gt; const&amp;, unsigned short); ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru