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

Почему в приведенном коде всегда первым отрицательным элементом является нулевой элемент

17.10.2012, 11:14. Показов 843. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Я туплю и не понимаю почему он всегда первым отрицательным элементом берёт нулевой элемент.
Исправьте, пожалуйста, чтобы работала корректно.


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
#include "stdafx.h"
#include <stdio.h>
#include <clocale>
#include <conio.h>
#include <iostream>
using namespace std;
 
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale (LC_ALL, "Russian");
    const int n=10;
    double a[n];
    double per=0;
    double vt;
    double sum=0;
    for ( int  i= 0; i < n; i++ )
{
    cout << endl << "Введите "<< i << " элемент массива" << endl;
    cin>>a[i];
}
    
 
  for  (int  i= 0; i < n; i++ ) {
        cout<<endl<< i << " элемент массива= " <<a[i]<<endl;
  }
    for  (int  i=0; i < n; i++ ) {
        if (a[i]<0 && per!=0) per=i;}
    for  (int  i=per; i < n; i++ ) {
        if (a[i]<0) vt=i;}
    for  (int  i=per+1; i < vt; i++ ) {
        sum=sum+a[i];
    }
 cout<<endl<<"Первый отрицательный элемент= "<<per<<endl;
 cout<<endl<<"Второй отрицательный элемент= "<<vt<<endl;
 cout<<endl<<"Сумма между отрицательными элементами= "<<sum<<endl;
_getch();
    //return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
17.10.2012, 11:14
Ответы с готовыми решениями:

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

В целочисленном массиве вставить новый элемент перед первым отрицательным элементом
В одномерном массиве, элементы которого - целые числа, произвести следующие действия. Вставить новый элемент перед первым отрицательным...

Получить разницу между первым элементом последовательности и числом, стоящим перед первым отрицательным
Даны действительные числа а1, а2, .... Известно, что а1&gt; 0 и что среди а2, а3, ... есть хотя бы одно отрицательное число. Пусть a1, ..., an...

5
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,170
Записей в блоге: 10
17.10.2012, 11:21
А что это вообще такое и как она должна работать?
0
0 / 0 / 0
Регистрация: 15.10.2012
Сообщений: 6
17.10.2012, 11:26  [ТС]
Она должна находить сумму элементов массива находящихся между первым и вторым отрицательными элементами массива.
Я думал по программе более менее понятно в чём суть...
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,170
Записей в блоге: 10
17.10.2012, 11:30
Сделай индексы на первый и второй отрицательный элемент типом int. Когда найдешь первый отрицательный элемент прерывай цикл break;-ом. Со вторым так же.
0
Неэпический
 Аватар для Croessmah
18146 / 10730 / 2066
Регистрация: 27.09.2012
Сообщений: 27,030
Записей в блоге: 1
17.10.2012, 11:32
C++
1
2
3
4
5
6
7
8
9
10
11
12
for (int i= 0; i < n; i++ ) {
cout<<endl<< i << " элемент массива= " <<a[i]<<endl;
}
for (int i=0; i < n; i++ ) {
    if (a[i]<0) {per=i;break;}
}
for (int i=per+1; i < n; i++ ) {
    if (a[i]<0) {vt=i;break;}
}
for (int i=per+1; i < vt; i++ ) {
sum=sum+a[i];
}
1
5500 / 4895 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
17.10.2012, 11:36
Цитата Сообщение от Zlou Посмотреть сообщение
for (int i=0; i < n; i++ ) {
if (a[i]<0 && per!=0) per=i;}
Вот здесь, как я понимаю, должен запоминаться индекс первого элемента меньше 0. Но запоминаться будет только если per != 0, а он равен 0 (в 15 строке). Потом, почему-то, в 35 строке выводится per (естественно будет 0). Должен выводится, по логике, a[per].
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.10.2012, 11:36
Помогаю со студенческими работами здесь

почему то первый в этом коде у меня не нулевой элемент а идет по порядку все
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &quot;conio.h&quot; #include &quot;locale.h&quot; #define countof(array) (sizeof(array) /...

Вычислить сумму элементов массива, расположенных за первым отрицательным элементом
Вот задача нужно решить - С++. Не могу решить, не получается, помогите пожалуйста. Вычислить сумму элементов массива С(25),...

Сумма элементов между первым положительным элементом массива и последним отрицательным
В одномерном целочисленном массиве( элементы массива генерируются случайным образом диапазоне от -100 до 100), подсчитать сумму элементов,...

Найти сумму элементов массива, находящихся между первым и последним отрицательным элементом
В целочисленном массиве из 20 ти элементов, найти сумму элементов, находящихся между первым и последним отрицательным элементом.Массив...

Получить b1,…,bn, где bi – это сумма элементов, расположенных за первым отрицательным элементом в i-й строки
пусть дано натуральное число n и целочисленная квадратная матрица порядка n. Получите b1,…,bn, где bi – это сумма элементов, расположенных...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
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, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru