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

Просуммировать все элементы массива, которые находятся между первым и последним нулем

05.11.2012, 15:24. Показов 1743. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня такая задача: мне надо просуммировать все элементы массива, которые находятся между первым нулем в массиве и последним нулем. Для этого я ищю индексы этих нулей и потом запускаю цикл для суммирования, НО 1-й ноль в массиве находит, а вот последний никак( выбивает 256. Что-то с циклом, но не пойму что. помогите пожалуйста.
Code
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
#include <vcl.h>
#pragma hdrstop
 
//---------------------------------------------------------------------------
 
#pragma argsused
#include <iostream.h>
#include <conio.h>
#include <math.h>
#include <windows.h>
int main(int argc, char* argv[])
{
SetConsoleOutputCP(1251);
int start,finish;
double n, dob=1,sum=0;
cout<<"Ââåä³òü ðîçì³ð ìàñèâó a: ";
cin>>n;
double *a=new double [n];
for (int i=0;i<n;i++)
{cout<<"mas a["<<i<<"]=";
cin>>a[i]; cout<<endl;}
for (int i=0;i<n;i++)
{
if((int)a[i] % 2==0 && a[i]-(int)a[i]==0 && a[i]!=0)
dob*=a[i]; }
cout<<"Äîáóòîê ïàðíèõ åëåìåíò³â= "<<dob<<endl;
//Ïîøóê ïåðøîãî ³ îñòàííüîãî íóëÿ
for (int i=0;i<n;i++)
{
if (a[i]==0)
start=i; break; }
cout<<start<<endl;
for (int i=n-1;n>i;i--)  // вот здесь походу что-то не так с циклом
{
if (a[i]==0)
finish=i; break; }  
cout<<finish<<endl;
for (int i=start;i<finish;i++)
{
sum+=a[i]; }
cout<<"Ñóìà= "<<sum;
 
for (int i=0;i<n;i++)   /* и вот еще тут я вывожу массив таким образом чтобы сначала выводились все элементы которые >=0 , а потом те, которые<0, но оно начинает не с 0 элемента, а с 1-го. почему так? в цикле же сказано с 0 элемента начинать (i=0) и инкремент стоит постфиксный, вроде все как надо*/
{                          
if (a[i]>=0)               
cout<<a[i]<<endl;}
for (int i=0;i<n;i++)
{
if (a[i]<0)
cout<<a[i]<<endl;}
getch();
return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.11.2012, 15:24
Ответы с готовыми решениями:

Вывести все элементы массива, которые находятся между двуямя числами, включая их
Доброго времени суток, формучане. Помогите, пожалуйста, с заданиями: 2. Массивы задать в коде программы. Функцию генерирования...

Вывести сумму чисел расположенных между первым и последним нулем
Дано целое число N и набор из N целых чисел, содержащий по крайней мере два нуля. Вывести сумму чисел из данного набора, расположенных...

Найти количество элементов массива, которые находится между первым и последним отрицательным элементом
Объявить и проинициализировать массив случайными числами в диапазоне . Найти сколько элементов находится между первым и последним...

14
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
05.11.2012, 15:41
Цитата Сообщение от Shef4u Посмотреть сообщение
C++
1
for (int i=n-1;n>i;i--) // вот здесь походу что-то не так с циклом
условие в цикле измените на: i>=0
0
15 / 15 / 4
Регистрация: 31.10.2011
Сообщений: 116
05.11.2012, 15:50  [ТС]
Цитата Сообщение от valeriikozlov Посмотреть сообщение
условие в цикле измените на: i>=0
спасибо, но всеровно 256 выбивает. такое ощущение что цикл не переходит на следующую итерацию так как если ввести в массиве ноль последним элементом то показывает правильно, а если, например, предпоследним то 256 пишет
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
05.11.2012, 16:19
Вот эту часть:
Цитата Сообщение от Shef4u Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
//Пошук першого і останнього нуля
for (int i=0;i<n;i++)
{
if (a[i]==0)
start=i; break; }
cout<<start<<endl;
for (int i=n-1;n>i;i--) // вот здесь походу что-то не так с циклом
{
if (a[i]==0)
finish=i; break; } 
cout<<finish<<endl;
замените на:
C++
1
2
3
4
5
6
7
8
9
//Пошук першого і останнього нуля
for (int i=0;i<n;i++)
    if (a[i]==0){
        start=i; break; }
cout<<start<<endl;
for (int i=n-1;i>=0;i--)  // вот здесь походу что-то не так с циклом
    if (a[i]==0){
finish=i; break; }  
cout<<finish<<endl;
0
15 / 15 / 4
Регистрация: 31.10.2011
Сообщений: 116
05.11.2012, 17:39  [ТС]
Цитата Сообщение от valeriikozlov Посмотреть сообщение
Вот эту часть:

замените на:
C++
1
2
3
4
5
6
7
8
9
//Пошук першого і останнього нуля
for (int i=0;i<n;i++)
    if (a[i]==0){
        start=i; break; }
cout<<start<<endl;
for (int i=n-1;i>=0;i--)  // вот здесь походу что-то не так с циклом
    if (a[i]==0){
finish=i; break; }  
cout<<finish<<endl;
нет, всеровно 256 выбивает...я думаю может вообще программу наново написать? но вроде пересмотрел код не нашел ничего чтобы могло влиять на finish
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
05.11.2012, 17:58
Цитата Сообщение от Shef4u Посмотреть сообщение
нет, всеровно 256 выбивает..
уже не должно выбивать.
Создайте новый проект. Скопируйте туда:
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
#include <vcl.h>
#pragma hdrstop
 
//---------------------------------------------------------------------------
 
#pragma argsused
#include <iostream.h>
#include <conio.h>
#include <math.h>
#include <windows.h>
int main(int argc, char* argv[])
{
SetConsoleOutputCP(1251);
int start,finish;
double n, dob=1,sum=0;
cout<<"Введіть розмір масиву a: ";
cin>>n;
double *a=new double [n];
for (int i=0;i<n;i++)
{cout<<"mas a["<<i<<"]=";
cin>>a[i]; cout<<endl;}
for (int i=0;i<n;i++)
{
if((int)a[i] % 2==0 && a[i]-(int)a[i]==0 && a[i]!=0)
dob*=a[i]; }
cout<<"Добуток парних елементів= "<<dob<<endl;
//Пошук першого і останнього нуля
for (int i=0;i<n;i++)
    if (a[i]==0){
        start=i; break; }
cout<<start<<endl;
for (int i=n-1;i>=0;i--)  // вот здесь походу что-то не так с циклом
    if (a[i]==0){
finish=i; break; }  
cout<<finish<<endl;
for (int i=start;i<finish;i++)
{
sum+=a[i]; }
cout<<"Сума= "<<sum;
 
for (int i=0;i<n;i++)   /* и вот еще тут я вывожу массив таким образом чтобы сначала выводились все элементы которые >=0 , а потом те, которые<0, но оно начинает не с 0 элемента, а с 1-го. почему так? в цикле же сказано с 0 элемента начинать (i=0) и инкремент стоит постфиксный, вроде все как надо*/
{                          
if (a[i]>=0)               
cout<<a[i]<<endl;}
for (int i=0;i<n;i++)
{
if (a[i]<0)
cout<<a[i]<<endl;}
getch();
return 0;
}
и запускайте.
1
15 / 15 / 4
Регистрация: 31.10.2011
Сообщений: 116
05.11.2012, 18:37  [ТС]
Цитата Сообщение от valeriikozlov Посмотреть сообщение
уже не должно выбивать.
Создайте новый проект. Скопируйте туда:
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
#include <vcl.h>
#pragma hdrstop
 
//---------------------------------------------------------------------------
 
#pragma argsused
#include <iostream.h>
#include <conio.h>
#include <math.h>
#include <windows.h>
int main(int argc, char* argv[])
{
SetConsoleOutputCP(1251);
int start,finish;
double n, dob=1,sum=0;
cout<<"Введіть розмір масиву a: ";
cin>>n;
double *a=new double [n];
for (int i=0;i<n;i++)
{cout<<"mas a["<<i<<"]=";
cin>>a[i]; cout<<endl;}
for (int i=0;i<n;i++)
{
if((int)a[i] % 2==0 && a[i]-(int)a[i]==0 && a[i]!=0)
dob*=a[i]; }
cout<<"Добуток парних елементів= "<<dob<<endl;
//Пошук першого і останнього нуля
for (int i=0;i<n;i++)
    if (a[i]==0){
        start=i; break; }
cout<<start<<endl;
for (int i=n-1;i>=0;i--)  // вот здесь походу что-то не так с циклом
    if (a[i]==0){
finish=i; break; }  
cout<<finish<<endl;
for (int i=start;i<finish;i++)
{
sum+=a[i]; }
cout<<"Сума= "<<sum;
 
for (int i=0;i<n;i++)   /* и вот еще тут я вывожу массив таким образом чтобы сначала выводились все элементы которые >=0 , а потом те, которые<0, но оно начинает не с 0 элемента, а с 1-го. почему так? в цикле же сказано с 0 элемента начинать (i=0) и инкремент стоит постфиксный, вроде все как надо*/
{                          
if (a[i]>=0)               
cout<<a[i]<<endl;}
for (int i=0;i<n;i++)
{
if (a[i]<0)
cout<<a[i]<<endl;}
getch();
return 0;
}
и запускайте.
спасибо!! работает! может еще подскажете почему сумму неправильно считает?

for (int i=start;i<finish;i++)
{
sum+=a[i]; }
cout<<"Сума= "<<sum;
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
05.11.2012, 18:54
Все правильно считает: между первым и последним нулем. Добавляется к сумме лишний 0, но на результат он не влияет. Напишите какой массив вводили, когда код неправильную сумму выдает.
0
15 / 15 / 4
Регистрация: 31.10.2011
Сообщений: 116
05.11.2012, 19:09  [ТС]
Цитата Сообщение от valeriikozlov Посмотреть сообщение
Все правильно считает: между первым и последним нулем. Добавляется к сумме лишний 0, но на результат он не влияет. Напишите какой массив вводили, когда код неправильную сумму выдает.
вот прилагаю скрин. выходит что 3+4=72
Миниатюры
Просуммировать все элементы массива, которые находятся между первым и последним нулем  
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
05.11.2012, 19:52
Цитата Сообщение от Shef4u Посмотреть сообщение
вот прилагаю скрин. выходит что 3+4=72
Покажите весь код. Я уже вижу что он отличается от того что я написал.
0
15 / 15 / 4
Регистрация: 31.10.2011
Сообщений: 116
05.11.2012, 19:53  [ТС]
Цитата Сообщение от valeriikozlov Посмотреть сообщение
Покажите весь код. Я уже вижу что он отличается от того что я написал.
да отличается только названием в "" сам код я не менял, вот:
Code
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
#include <vcl.h>
#pragma hdrstop
 
//---------------------------------------------------------------------------
 
#pragma argsused
#include <iostream.h>
#include <conio.h>
#include <math.h>
#include <windows.h>
int main(int argc, char* argv[])
{
SetConsoleOutputCP(1251);
int start,finish;
double n, dob=1,sum;
cout<<"Ââåä³òü ðîçì³ð ìàñèâó a: ";
cin>>n;
double *a=new double [n];
for (int i=0;i<n;i++)
{cout<<"mas a["<<i<<"]=";
cin>>a[i]; cout<<endl;}
for (int i=0;i<n;i++)
{
if((int)a[i] % 2==0 && a[i]-(int)a[i]==0 && a[i]!=0)
dob*=a[i]; }
cout<<"Äîáóòîê ïàðíèõ åëåìåíò³â= "<<dob<<endl;
//Ïîøóê ïåðøîãî ³ îñòàííüîãî íóëÿ
for (int i=0;i<n;i++)
    if (a[i]==0){
        start=i; break; }
cout<<"ïåðøèé 0 ìຠ³íäåêñ: "<<start<<endl;
for (int i=n-1;i>=0;i--)
    if (a[i]==0) {
finish=i; break; }
cout<<"îñòàíí³é 0 ìຠ³íäåêñ: "<<finish<<endl;
for (int i=start;i<finish;i++)
 { sum+=a[i]; }
cout<<"Ñóìà ì³æ ïåðøèì ³ îñòàíí³ì= "<<sum;
 
for (int i=0;i<n;i+=1)
{
if (a[i]>=0)
cout<<a[i]<<endl;}
for (int i=0;i<n;i++)
{
if (a[i]<0)
cout<<a[i]<<endl;}
getch();
return 0;
}
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
05.11.2012, 19:58
Цитата Сообщение от Shef4u Посмотреть сообщение
да отличается только названием в "" сам код я не менял, вот:
Да нет, меняли.
Строку 16 Вашей версии:
Цитата Сообщение от Shef4u Посмотреть сообщение
C++
1
double n, dob=1,sum;
замените на:
C++
1
double n, dob=1,sum=0;
1
15 / 15 / 4
Регистрация: 31.10.2011
Сообщений: 116
05.11.2012, 20:00  [ТС]
Цитата Сообщение от valeriikozlov Посмотреть сообщение
Да нет, меняли.
Строку 16 Вашей версии:

замените на:
C++
1
double n, dob=1,sum=0;
а, извините, просто перебирал разные варианты. если сделать так как вы сказали ничего не изменится, сумма всеровно не правильно считается..
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
05.11.2012, 20:08
Цитата Сообщение от Shef4u Посмотреть сообщение
сумма всеровно не правильно считается..
сумма считается правильно, просто потом к выведенной на экран 7 дописывается число 2 из этого цикла:

Цитата Сообщение от Shef4u Посмотреть сообщение
C++
1
2
3
4
for (int i=0;i<n;i+=1)
{
if (a[i]>=0)
cout<<a[i]<<endl;}
Вот эту строку:
Цитата Сообщение от Shef4u Посмотреть сообщение
C++
1
cout<<"Сума між першим і останнім= "<<sum;
замените на:
C++
1
cout<<"Сума між першим і останнім= "<<sum<<endl;
1
15 / 15 / 4
Регистрация: 31.10.2011
Сообщений: 116
05.11.2012, 20:12  [ТС]
Цитата Сообщение от valeriikozlov Посмотреть сообщение
сумма считается правильно, просто потом к выведенной на экран 7 дописывается число 2 из этого цикла:



Вот эту строку:

замените на:
C++
1
cout<<"Сума між першим і останнім= "<<sum<<endl;
вот я лох!! забыл поставить переход на новую строчку и вроде как пересматривал код 100 раз и не заметил( СПАСИБО ВАМ ОГРОМНОЕ!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.11.2012, 20:12
Помогаю со студенческими работами здесь

Вывести сумму чисел из данного набора, расположенных между первым и последним нулем
Дано целое число N и набор из N целых чисел, содержащий по крайней мере два нуля. Вывести сумму чисел из данного набора, расположенных ...

Вывести сумму чисел из данного набора, расположенных между первым и последним нулем
программа на языке С++ Дано целое число N и набор из N целых чисел, содержащий по крайней мере два нуля. Вывести сумму чисел из данного...

Удалить из массива элементы, расположенные между первым и последним нулевыми элементами
Задан массив действительных чисел b1,...b30. Удалить из него элементы, расположенные между первым и последним нулевыми элементами

Упорядочить по убыванию элементы массива между первым положительным и последним отрицательным
Упорядочить в порядке убывания элементы массива, расположенные между первым положительным и последним отрицательным значениями массива

Упорядочить по убыванию элементы массива, стоящие между первым максимальным и последним минимальным
Упорядочить по убыванию элементы массива, стоящие между первым максимальным и последним минимальным элементами.(массив целочисленный)


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru