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

Вернуть индекс последнего с конца элемента E в векторе V

14.06.2017, 00:13. Показов 6814. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
подскажите нужно сделать следующие
------find_last(v, e) - вернуть индекс элемента e в векторе v, но последний с конца----
написал вот такую программку.немного запутался
как найти индекс элемента с начала вектора разобрался
вот собственно 2 функции
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
int find(vector<int> &v,int e)
{
    for(int i = 0; i < v.size(); i++)
    {
        if (v[i] == e)
        {
            cout<< i << endl;
        }        
    }    
}  
int find_last(vector<int> &v,int  e)
{
    for ( int i = v.size()+1; i>v.size(); i--)
    {
        if (v[i] == e)
        {
            cout<< i << endl;
        }        
    }    
}
find работает как и задумывалось
а вот find_last выдает 6.помогите разобраться
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.06.2017, 00:13
Ответы с готовыми решениями:

Дан линейный массив. Найти третий с конца элемент и в качестве ответа вернуть его индекс
Здравствуйте, пожалуйста, помогите найти и исправить ошибку. Заранее спасибо. Задача: Дан линейный массив. Найти третий с конца элемент и...

В векторе (одномерном массиве) найти: разность первого положительного и последнего отрицательного элемента
В заданном векторе (одномерном массиве) найти: разность первого положительного и последнего отрицательного элемента

Индекс последнего элемента в ListBox
Добрый день. Подскажите, пожалуйста, как узнать индекс последнего элемента ListBox?

9
Эксперт .NET
 Аватар для Даценд
5878 / 4755 / 2939
Регистрация: 20.04.2015
Сообщений: 8,361
14.06.2017, 00:18
Попробуйте:
C++
13
for ( int i = v.size()-1; i>=0; i--)
Ну и
C++
17
return i;
0
296 / 125 / 106
Регистрация: 30.10.2015
Сообщений: 690
14.06.2017, 02:11
Цитата Сообщение от swswsss Посмотреть сообщение
C++
1
for(int i = 0; i < v.size(); i++)
Не лучше ли будет создать константу, которая будет хранить v.size()?
0
Велосипедист...
 Аватар для Mournful Max
353 / 220 / 73
Регистрация: 15.12.2015
Сообщений: 785
14.06.2017, 02:13
Nemovok, я думаю, речь об оптимизации здесь не к месту
0
0 / 0 / 5
Регистрация: 20.12.2016
Сообщений: 157
14.06.2017, 03:48  [ТС]
Цитата Сообщение от Nemovok Посмотреть сообщение
Не лучше ли будет создать константу, которая будет хранить v.size()?
я кинул не весь код программы
всем спасибо)
0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
14.06.2017, 06:05
Цитата Сообщение от Nemovok Посмотреть сообщение
Не лучше ли будет создать константу, которая будет хранить v.size()?
метод size() имеет константную сложность и это не имеет смысла, т.к. даже при -О1 эта функция будет в нормальных компиляторах заинлайнена.
Цитата Сообщение от swswsss Посмотреть сообщение
find работает как и задумывалось
ага, а ещё там UB.
Цитата Сообщение от swswsss Посмотреть сообщение
а вот find_last выдает 6.помогите разобраться
входные данные и ожидаемый результат нам знать не обязательно, тут же все телепаты, так?
std::find в помощь.
http://en.cppreference.com/w/cpp/algorithm/find
0
 Аватар для Nishen
1358 / 856 / 366
Регистрация: 26.02.2015
Сообщений: 3,816
14.06.2017, 07:35
Цитата Сообщение от GbaLog- Посмотреть сообщение
ага, а ещё там UB.
Почему, можешь объяснить?
0
с++
1282 / 523 / 225
Регистрация: 15.07.2015
Сообщений: 2,562
14.06.2017, 08:09
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
int find(const vector<int>&vec,  const int value)
{
    int a = 0;
    for (a = 0; a < vec.size(); ++a) {
        if (vec[a] == value) {
            return a;
        }
    }
    return a;
}
int  find_last(const vector<int>&vec, const int value)
{
    int a = 0;
    for ( a = vec.size()-1; a>=0; --a){
        if (vec[a] == value) {
            return a;
        }
    }
    return a;   
}
0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
14.06.2017, 08:12
Цитата Сообщение от Nishen Посмотреть сообщение
Почему, можешь объяснить?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <iostream>
#include <vector>
 
using namespace std;
 
int find(vector<int> &v,int e)
{
    for(int i = 0; i < v.size(); i++)
    {
        if (v[i] == e)
        {
            cout<< i << endl;
        }        
    }    
}  
 
int main()
{
    std::vector<int> v{ 1, 2, 3 };
    
    int n = find(v, 1); //что вернется из find?
}
1
с++
1282 / 523 / 225
Регистрация: 15.07.2015
Сообщений: 2,562
14.06.2017, 08:21
Цитата Сообщение от GbaLog- Посмотреть сообщение
C++
1
//что вернется из find?
бублик вернется , ну или ошибка компиляции вернется
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.06.2017, 08:21
Помогаю со студенческими работами здесь

Найти индекс последнего отрицательного элемента массива
Создать массив, в котором 14 элементов. Найти индекс последнего отрицательного элемента массива. Вывести первоначальный массив и найденный...

Вывести индекс последнего чётного элемента списка
Задан массив целых чисел, размерностью 20. Вывести индекс его последнего парного элемента. Как реализовать? Спасибо

Вернуть список кортежей, отсортированных в порядке возрастания последнего элемента
Дан список не пустых кортежей. Вернуть список кортежей, отсортированных в порядке возрастания последнего элемента. Пример: выдаст

Индекс первого и последнего элемента в коллекции с определенным классом
допустим я выбрал коллекцию элементов по id: var element = document.getElementById('posts') надо определить индекс первого и последнего...

Определить индекс первого и последнего нулевого элемента массива
Определить индекс первого и последнего нулевого элемента массива


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru