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

Почему возвращает длину массива равной 0

08.06.2023, 12:53. Показов 703. Ответов 12
Метки c++ (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите пожалуйста что не так. Вроде заполняю массив, но возвращает его длину нулём. Также программа почему - то мало оптимизирована(вложенный цикл при данных тестах ни при чём, на питоне проходит за 0,357 секунд, тут 1,1, подозреваю, что виноват метод find, если так, то подскажите чем его можно заменить)






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
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
using namespace std;
 
int main()
{
int t,n;
string s,p;
cin>>t;
vector<string> arr;
for ( int i = 0; i < t; ++i)
{
    cin>>n>>s;
    for (int g = 0; g < n - 1; g ++)
    {
        p = s[g]+s[g+1];
        bool flag = find(begin(arr), end(arr), p) != end(arr);
        if (flag)
        {arr.push_back(p);}
 
    }
 
cout<<int (arr.size())<<"\n";
arr.clear();
    }
 
}
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
08.06.2023, 12:53
Ответы с готовыми решениями:

Почему-то возвращает исключение при сортировки пузырьком массива строк
Не понимаю в чем дело, просто переделал сортировку пузырьком под массив строк. Задание из Шилдта. string sorter = { &quot;Kiss&quot;,...

Почему константная функция возвращает скаляр а не массив при передаче в неё массива?
Есть массив. К примеру X = Есть функция вида f(x) = const. К примеру f = @(x)2 В функцию передаётся массив: f(X) Ожидаемый...

Почему переменная g после switch-а становится равной нулю?
Здравствуйте! На скрине код и тест. Не могу понять в чем проблема( код с ошибкой, с code::blocks или еще что-то), почему переменная g после...

12
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
08.06.2023, 13:21
какие входные данные?

Добавлено через 42 секунды
Цитата Сообщение от Maxim_rus_nev Посмотреть сообщение
Вроде заполняю массив,
Я не понимаю - вам запрещают пользоваться отладчиком? или как обычно "онлайн курсы, тесты не проходит"?
0
19500 / 10105 / 2461
Регистрация: 30.01.2014
Сообщений: 17,816
08.06.2023, 13:24
Цитата Сообщение от Maxim_rus_nev Посмотреть сообщение
C++
1
2
3
bool flag = find(begin(arr), end(arr), p) != end(arr);
 if (flag)
 {arr.push_back(p);}
У вас в процитированном фрагменте написано (по-русски): "добавь в вектор строку p, если там уже есть такая строка хотя бы один раз".
Совершенно очевидно, что при таком условии и при условии, что вектор изначально пуст, туда не добавится вообще ничего и никогда.
1
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
08.06.2023, 13:25
Цитата Сообщение от DrOffset Посмотреть сообщение
Нет, find - это линейный поиск.
Да, я наврал, сорри
0
19500 / 10105 / 2461
Регистрация: 30.01.2014
Сообщений: 17,816
08.06.2023, 13:32

Не по теме:

Цитата Сообщение от KSergey9 Посмотреть сообщение
Да, я наврал, сорри
Да я удалил уже это замечание, когда увидел отредактированный пост :)
Можно считать, что ничего не было.



Добавлено через 4 минуты
Цитата Сообщение от Maxim_rus_nev Посмотреть сообщение
программа почему - то мало оптимизирована
Чтобы ответить на это, нужно знать задание. Задание вы не привели, ответа значит нет, есть только предположения. Может быть вы просто в отладочном режиме проверяете?
Особенно странно звучит предположение про медленный find, хотя как мы выяснили ранее, здесь заведомо известно, что он всегда работает на пустом векторе, а значит в сущности ничего не стоит.
0
0 / 0 / 0
Регистрация: 01.12.2022
Сообщений: 25
08.06.2023, 13:43  [ТС]
Цитата Сообщение от DrOffset Посмотреть сообщение
У вас в процитированном фрагменте написано (по-русски): "добавь в вектор строку p, если там уже есть такая строка хотя бы один раз".
Совершенно очевидно, что при таком условии и при условии, что вектор изначально пуст, туда не добавится вообще ничего и никогда.
Цитата Сообщение от DrOffset Посмотреть сообщение
У вас в процитированном фрагменте написано (по-русски): "добавь в вектор строку p, если там уже есть такая строка хотя бы один раз".
Совершенно очевидно, что при таком условии и при условии, что вектор изначально пуст, туда не добавится вообще ничего и никогда.
Подскажите пожалуйста как исправить это. В if добавить !flag или что то в find изменить

Добавлено через 1 минуту
Цитата Сообщение от KSergey9 Посмотреть сообщение
Я не понимаю - вам запрещают пользоваться отладчиком? или как обычно "онлайн курсы, тесты не проходит"?
Я знаю про отладчик. Но вот незадача, в Codeblocks он почему-то не работает, хотя он должен быть установлен. Кнопки просто горят серым .
0
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
08.06.2023, 13:44
Цитата Сообщение от Maxim_rus_nev Посмотреть сообщение
в Codeblocks
Поставьте локально любой компилятор с отладчиком (бесплатный вариант Visual Studio, например) - и прекратте уже себя мучать.
0
0 / 0 / 0
Регистрация: 01.12.2022
Сообщений: 25
08.06.2023, 13:46  [ТС]
Хорошо, а чем плох Codeblocks?
0
631 / 526 / 104
Регистрация: 05.08.2022
Сообщений: 2,810
08.06.2023, 13:57
Цитата Сообщение от Maxim_rus_nev Посмотреть сообщение
Хорошо, а чем плох Codeblocks?
Тем что в нём нет отладчика, надо полагать?

Добавлено через 2 минуты
Хотя, скорее всего, надо просто почитать справку как дебажный вариант собрать
https://wiki.codeblocks.org/in... de::Blocks
0
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6218 / 2914 / 1046
Регистрация: 01.06.2021
Сообщений: 10,772
08.06.2023, 14:30
Цитата Сообщение от KSergey9 Посмотреть сообщение
Тем что в нём нет отладчика, надо полагать?
в Code::Blocks есть инструменты для отладки!

Цитата Сообщение от Maxim_rus_nev Посмотреть сообщение
Я знаю про отладчик. Но вот незадача, в Codeblocks он почему-то не работает.
Либо не настроен отладчик в самой IDE, либо неправильно собираете проект для отладочной версии
0
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
12938 / 6805 / 1821
Регистрация: 18.10.2014
Сообщений: 17,227
08.06.2023, 17:45
Цитата Сообщение от Maxim_rus_nev Посмотреть сообщение
p = s[g]+s[g+1];
Что по вашему здесь делается?

Цитата Сообщение от Maxim_rus_nev Посмотреть сообщение
Вроде заполняю массив
"Вроде заполняю"? То ест вы уверены, что push_back вызывался?
0
0 / 0 / 0
Регистрация: 01.12.2022
Сообщений: 25
08.06.2023, 18:43  [ТС]
Цитата Сообщение от TheCalligrapher Посмотреть сообщение
Что по вашему здесь делается?
Я понял, что ошибка в этом месте и исправил её. Но не могу понять почему это ошибка. Я в строку (пустую) добавляю сумму двух строк. Почему это было не верно?
0
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
12938 / 6805 / 1821
Регистрация: 18.10.2014
Сообщений: 17,227
08.06.2023, 20:00
Лучший ответ Сообщение было отмечено Maxim_rus_nev как решение

Решение

Цитата Сообщение от Maxim_rus_nev Посмотреть сообщение
Я в строку (пустую) добавляю сумму двух строк.
"Сумму двух строк"? Но s[g] и s[g+1] - это никакие не строки. Это индивидуальные символы. С++ - это не Питон. В С++ индивидуальные символы - это не строки. Это целые числа. И s[g]+s[g+1] - это просто сумма двух целых чисел, а не конкатенация двух строк.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.06.2023, 20:00
Помогаю со студенческими работами здесь

Найти длину максимальной подстроки, такой что в этой подстроке не существует подстроки равной какой-то строке
Не могу решить задачу, я понял саму задачу. Не могу написать код, помогите, плз! У Дроида-На2а есть строка S, и K строк ai. Ваша задача...

залить из двумерного массива данные в одномерный длиной, равной количеству всех элементов исходного массива
Доброго времени суток :) Образовался новый глупый вопрос... Предположим у меня есть двухмерный массив: vertex** massiv() { ...

Как вывести элемент массива a на позиции, равной сумме позиций минимального и максимального элемента массива?
Нужно вывести элемент массива a на позиции, равной сумме позиций минимального и максимального элемента массива. Input: В первой строке...

Дан текстовый файл. В каждой строке файла подсчитать среднюю длину слов. В новый файл запись слова с длиной большей и равной средней, оставляя нужные
Дан текстовый файл. В каждой строке файла подсчитать среднюю длину слов. В новый файл запись слова с длиной большей и равной средней,...

Какая функция возвращает длину строки?
Подскажите пожалуйста! Какая функция возвращает длину строки в С#?


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru