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

Найти сумму чисел между первым и последним отрицательным числом массива

31.01.2020, 13:57. Показов 4912. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста решить задачу. Нужно найти первое и последнее отрицательные числа в массиве и найти сумму элементов между ними.
Заранее спасибо за помощь
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.01.2020, 13:57
Ответы с готовыми решениями:

Почему не считает сумму элементов, между первым и последним отрицательным элементом?
С# Почему не считает сумму элементов, между первым и последним отрицательным элементом class Program { ...

Нужно рассчитать сумму и диапазон чисел между первым и последним отрицательным числом в массиве
#include <iostream> using namespace std; int main() { int n,c=0,i,s=0; cout << "Input massive size \n"; cin >> n; ...

Найти суму чисел находящихся между первым и последним отрицательным числом в массиве - Проверить на ошибки
1)Найти суму чисел находяшихся между первым и последним отрицательным числом в массиве Статический массив #include <stdio.h> ...

12
 Аватар для Anvean
63 / 55 / 10
Регистрация: 12.02.2019
Сообщений: 303
31.01.2020, 16:32
Vamp1RR,
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
static void Main(string[] args)
        {
            Console.WriteLine("Введите длинну массива");
            int [] m = new int[int.Parse(Console.ReadLine())];
            Fill(m);
            Print(m);
            Console.WriteLine("\nСумма : "+m.SkipWhile(x => x < 0).Reverse().SkipWhile(x => x < 0).Sum());
            Console.ReadKey();
        }
        private static void Fill(int[] matrix)
        {
            for (int i = 0; i < matrix.GetLength(0); i++)
            {
                Console.WriteLine($"Введите {i} число ");
                matrix[i] = int.Parse(Console.ReadLine());
            }
        }
        private static void Print(int[] matrix)
        {
            for (int i = 0; i < matrix.GetLength(0); i++)
            {
                    Console.Write(matrix[i] + " ");
            }
        }
0
16 / 12 / 4
Регистрация: 10.09.2018
Сообщений: 373
31.01.2020, 17:34
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
static void Main(string[] args)
        {
            int[] arr = new int[10] { 2, -3, 4, 1, -4, 3, -4, 5, -5, 4 };
            int first = 0;
            int last = 0;
            int count = 0;
 
            // Поиск первого отрицательного числа
            for (int i = 0; i < arr.Length; i++)
            {
                if (arr[i] < 0)
                {
                    first = i;
                    break;
                }
            }
 
            // Поиск последнего отрицательного числа
            for (int i = 0; i < arr.Length; i++)
            {
                if (arr[i] < 0)
                {
                    last = i;
                }
            }
 
            // Нахождение суммы
            for (int i = 0; i < arr.Length; i++)
            {
                if (i > first)
                {
                    if (i< last)
                    {
                        count += arr[i];
                    }
                    
                }
            }
            Console.WriteLine("Сумма элементов равна: "+count);
 
            Console.ReadLine();
        }
0
 Аватар для jester
352 / 247 / 76
Регистрация: 18.03.2016
Сообщений: 979
31.01.2020, 17:38
Anvean, ты пропускаешь все отрицательные числа)

Добавлено через 1 минуту
DragonBorn88, последнее число искать логичнее с конца)

Добавлено через 1 минуту
DragonBorn88, а для подсчёта суммы задать границы цикла first last вместо этих if-ов
0
 Аватар для Enifan
1849 / 1191 / 501
Регистрация: 14.10.2018
Сообщений: 3,211
31.01.2020, 17:51
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
        int[] arr = { 2, -3, 4, 1, -4, 3, -4, 5, -5, 4 };
        int first = 0, last = arr.Length - 1, total = 0;
 
        for (; first < arr.Length; first++)
        {
            if (arr[first] < 0)
                break;
        }
 
        for (; last > first; last--)
        {
            if (arr[last] < 0)
                break;
        }
 
        /* Можно сделать проверку на кол-во отрицательных элементов,
           или если они рядом и высчитывать нечего */
 
        for (first++; first < last; first++)
            total += arr[first];
 
        Console.WriteLine("Итого: " + total);
0
16 / 12 / 4
Регистрация: 10.09.2018
Сообщений: 373
31.01.2020, 18:04
Цитата Сообщение от jester Посмотреть сообщение
последнее число искать логичнее с конца)
Да кстати, ты прав, я об этом даже не подумал. Набросал на скорую руку)
0
 Аватар для Anvean
63 / 55 / 10
Регистрация: 12.02.2019
Сообщений: 303
02.02.2020, 17:29
jester, Я вроде все тестил, что не так не пойму?
0
Модератор
Эксперт .NET
 Аватар для Элд Хасп
16140 / 11264 / 2888
Регистрация: 21.04.2018
Сообщений: 33,109
Записей в блоге: 2
02.02.2020, 17:41
Цитата Сообщение от Anvean Посмотреть сообщение
jester, Я вроде все тестил, что не так не пойму?
Условия перепутаны.
Надо отбросить с двух сторон неотрицательные элементы
C#
7
            Console.WriteLine("\nСумма : "+m.SkipWhile(x => x >= 0).Reverse().SkipWhile(x => x >= 0).Sum());
Добавлено через 4 минуты
Цитата Сообщение от jester Посмотреть сообщение
DragonBorn88, а для подсчёта суммы задать границы цикла first last вместо этих if-ов
DragonBorn88, Enifan, лучше так (как подсказал jester)
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
        int[] arr = { 2, -3, 4, 1, -4, 3, -4, 5, -5, 4 };
        int first = 0, last = arr.Length - 1, total = 0;
 
        for (; first < arr.Length && arr[first] <= 0; first++);
 
        for (; last > first && arr[last] <= 0; last--);
 
        /* Можно сделать проверку на кол-во отрицательных элементов,
           или если они рядом и высчитывать нечего */
 
        for (first++; first < last; first++)
            total += arr[first];
 
        Console.WriteLine("Итого: " + total);
1
 Аватар для Enifan
1849 / 1191 / 501
Регистрация: 14.10.2018
Сообщений: 3,211
02.02.2020, 18:17
Цитата Сообщение от Элд Хасп Посмотреть сообщение
лучше так (как подсказал jester)
в принципе я так и делал. Но сделать все в условии цикла (без блока кода) - хорошая идея

А насчет вашего кода - то ли я что то не понимаю, но:
1) почему вы делаете сравнение <=. Ведь нуль не относится к отрицательным числам
2) циклы на 4 и 6 строке не делают ни одной итерации. По идее должно быть сравнение >= или >

если сокращать, то сокращать цикл 11-12 строки на
C#
1
2
        while (++first < last)
            total += arr[first];
1
Модератор
Эксперт .NET
 Аватар для Элд Хасп
16140 / 11264 / 2888
Регистрация: 21.04.2018
Сообщений: 33,109
Записей в блоге: 2
02.02.2020, 18:37
Цитата Сообщение от Enifan Посмотреть сообщение
1) почему вы делаете сравнение <=. Ведь нуль не относится к отрицательным числам
2) циклы на 4 и 6 строке не делают ни одной итерации. По идее должно быть сравнение >= или >
Невнимательность. Пишу здесь в редакторе сообщений и не проверял.
Конечно, условия не верны
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
        int[] arr = { 2, -3, 4, 1, -4, 3, -4, 5, -5, 4 };
        int first = 0, last = arr.Length - 1, total = 0;
 
        for (; first < arr.Length && arr[first] >= 0; first++);
 
        for (; last > first && arr[last] >= 0; last--);
 
        /* Можно сделать проверку на кол-во отрицательных элементов,
           или если они рядом и высчитывать нечего */
 
        for (first++; first < last; first++)
            total += arr[first];
 
        Console.WriteLine("Итого: " + total);
Добавлено через 2 минуты
Цитата Сообщение от Enifan Посмотреть сообщение
если сокращать, то сокращать цикл 11-12 строки на
C#
1
for (first++; first < last; total+= arr[first++]);
Добавлено через 12 минут
Ещё вариант
C#
1
for (; ++first < last; total+= arr[first]);
1
 Аватар для jester
352 / 247 / 76
Регистрация: 18.03.2016
Сообщений: 979
02.02.2020, 18:47
Элд Хасп, Enifan, Я победил)
C#
1
Console.WriteLine($"Итого: {arr[first+1..last].Sum()}");
Добавлено через 3 минуты
C#
1
2
3
4
5
6
int[] arr = { 2, -3, 4, 1, -4, 3, -4, 5, -5, 4 };
 
int first = Array.FindIndex(arr, x => x < 0);
int last = Array.FindLastIndex(arr, x => x < 0);
 
Console.WriteLine($"Итого: {arr[first+1..last].Sum()}");
Добавлено через 1 минуту
шах и мат, программисты))
1
Модератор
Эксперт .NET
 Аватар для Элд Хасп
16140 / 11264 / 2888
Регистрация: 21.04.2018
Сообщений: 33,109
Записей в блоге: 2
02.02.2020, 18:55
Цитата Сообщение от jester Посмотреть сообщение
Я победил)
Не!!!!
Соревнование было - Без методов LINQ!
Sum() - это тоже LINQ!

Добавлено через 1 минуту
шах и мат, программисты
0
 Аватар для jester
352 / 247 / 76
Регистрация: 18.03.2016
Сообщений: 979
02.02.2020, 19:41
Элд Хасп, без LINQ нельзя.

C#
1
2
//Anvean
Console.WriteLine($"Итого: {arr.SkipWhile(x=>x>0).Skip(1).Reverse().SkipWhile(x=>x>0).Skip(1).Sum()}");
C#
1
2
//jester
Console.WriteLine($"Итого: {arr[Array.FindIndex(arr,x=>x<0)+1..Array.FindLastIndex(arr,x=>x<0)].Sum()}");
2 символа((
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.02.2020, 19:41
Помогаю со студенческими работами здесь

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

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

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

Вывести сумму элементов массива, расположенных между первым и последним отрицательным элементом
Как сделать так, чтобы из массива написанного от руки, выводил сумму элементов , расположенные между первым и последним отрицательным...

Вычислить сумму элементов массива, расположенных между первым и последним отрицательным элементами
- сумму элементов массива, расположенных между первым и последним отрицательным элементами


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
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