Форум программистов, компьютерный форум, киберфорум
Наши страницы

C# для начинающих

Войти
Регистрация
Восстановить пароль
 
gylayko
30 / 29 / 4
Регистрация: 28.09.2011
Сообщений: 448
#1

Найти произведение элементов массива расположенных между первым и вторым нулевыми элементами - C#

02.03.2013, 18:55. Просмотров 1064. Ответов 11
Метки нет (Все метки)

нужно найти произведение элементов массива расположенных между первым и вторым нулевыми элементами
C#
1
2
3
4
5
            for (int I = 0; I < n; I++)           
           { if (Arr[I] == 0) { Console.WriteLine("первый нулевой элемент = " + (I + 1)); per = I+1;  break; } }
            for (int I = per; I < n; I++)
            { if (Arr[I] == 0) { Console.WriteLine("второй нулевой элемент = " + (I + 1)); I = vtor;  break; } }
            for (int I = per; I < vtor; I++) { proiz = proiz*Arr[I]; }
в результате всегда 1, так как я сначала присвоил proiz=1, то есть ничего не меняется. где ошибка?
хотя, позиции первого и второго нулевых выводит правильно!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.03.2013, 18:55
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Найти произведение элементов массива расположенных между первым и вторым нулевыми элементами (C#):

Найти произведение элементов массива, расположенных между первым и вторым нулевыми элементами - C#
произведение элементов массива, расположенных между первым и вторым нулевыми элементами

Найти произведение элементов массива, расположенных между первым и вторым нулевыми элементами - C#
Добрый день!помогите пожалуйста с массивами, а то их плохо понимаю. I.в одномерном массиве, состоящем из N целочисленных элементов,...

Найти произведение элементов массива, расположенных между первым и вторым нулевыми элементами - C#
произведение элементов массива, расположенных между первым и вторым нулевыми элементами. Преобразовать массив таким образом, чтобы в первой...

Массив: произведение элементов массива, расположенных между первым и вторым нулевыми элементами - C#
всем привет! помогите пожалуйста! не могу сделать :( в одномерном массиве, состоящем из n целых элементов, вычислить: 1) номер...

Вычислить произведение элементов массива, расположенных между первым и вторым нулевыми элементами - C#
Задача: В одномерном массиве,состоящем из n целочисленных элементов вычислить произведение элементов массива, расположенных между первым и...

Массив: произведение элементов массива, расположенных между первым и вторым нулевыми элементами. - C#
Здравствуйте. Помогите пожалуйста написать следующую программу в консоле и составить к этой программе блок схему. Задача. В одномерном...

11
kontuPauk
300 / 298 / 66
Регистрация: 29.01.2013
Сообщений: 638
Записей в блоге: 1
Завершенные тесты: 1
02.03.2013, 19:09 #2
C#
1
Console.WriteLine("второй нулевой элемент = " + (I + 1)); I = vtor;
Вот тут вы перепутали I и vtor;
У vtor - пожизненный 0.
1
adm_loro
Заблокирован
02.03.2013, 21:07 #3
gylayko, ну опять же это однопроходной алгоритм, т.е. достаточно одного цикла.

Добавлено через 2 минуты
наткнулся на 0 считаем произведение, наткнулся второй - вышли из цикла. Написали ответ - ВСЁ.
0
andrew_w2k
323 / 323 / 10
Регистрация: 04.03.2010
Сообщений: 648
02.03.2013, 21:09 #4
C#
1
var mult = array.SkipWhile(x => x != 0).Skip(1).TakeWhile(z => z != 0).Aggregate((x, p) => x * p);
на заметку
0
adm_loro
Заблокирован
02.03.2013, 21:22 #5
andrew_w2k, хреновая заметка, это задача не на то как ты круто знаешь Linq, а на способность написать быстрый и понятный алгоритм.
1. SkipWhile(x => x != 0) создали первую обертку над массивом
2. Skip(1) 2- ю
3. TakeWhile(z => z != 0) - 3- ю
4. Aggregate((x, p) => x * p) - начинаем перебирать
и того 3 никому ненужных враппера и три делегата.

Добавлено через 2 минуты
Цитата Сообщение от andrew_w2k Посмотреть сообщение
SkipWhile(x => x != 0).Skip(1).TakeWhile(z => z != 0)
когда появилось Linq я думал, что оптимизатор справляется с такими выражениями, но увы.
0
andrew_w2k
323 / 323 / 10
Регистрация: 04.03.2010
Сообщений: 648
02.03.2013, 21:42 #6
а по-моему эта задача была на то, как я круто знаю linq
C#
1
2
3
4
5
6
7
8
9
10
11
12
for (int i = 0; i < array.Length; i++)
            {
                if(array[i] == 0) 
                {
                    i++;
                    while(array[i] != 0)
                    {
                        mult = mult * array[i];
                        i++;
                    }
                }
            }
0
adm_loro
Заблокирован
02.03.2013, 21:44 #7
andrew_w2k,
Цитата Сообщение от andrew_w2k Посмотреть сообщение
while(array[i] != 0)
* * * * * * * * * * {
* * * * * * * * * * * * mult = mult * array[i];
* * * * * * * * * * * * i++;
* * * * * * * * * * }
зачем?
1
andrew_w2k
323 / 323 / 10
Регистрация: 04.03.2010
Сообщений: 648
02.03.2013, 21:46 #8
оп да... тупо линк переписал.
0
kontuPauk
300 / 298 / 66
Регистрация: 29.01.2013
Сообщений: 638
Записей в блоге: 1
Завершенные тесты: 1
02.03.2013, 22:04 #9
Именно тупо. Вот не будет второго нулевого элемента в вашем массиве и пользователь программы этого не поймет...
0
andrew_w2k
323 / 323 / 10
Регистрация: 04.03.2010
Сообщений: 648
02.03.2013, 22:23 #10
критики такие критики...
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
int mult = 1; bool c = false;
            for (int i = 0; i < array.Length; i++)
            {
                if (array[i] != 0)
                {
                    if (c)
                        mult *= array[i];
                }
                else
                {
                    c = !c; 
                }
            }
Добавлено через 2 минуты
только счетчик ещё поставить на вхождение нулевых и соответственно break после второго

Добавлено через 6 минут
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
int mult = 1; int countZero = 0;
            for (int i = 0; i < array.Length; i++)
            {
                if (array[i] != 0)
                {
                     if (countZero == 1)
                        mult *= array[i];
                }
                else
                {
                    countZero++;
                }
            }
0
adm_loro
Заблокирован
03.03.2013, 03:10 #11
kontuPauk, дружище, если ты не в курсе про такие задачи, то не стоит бросаться словами. Задачи на составление алгоритма всегда имеют корректные входные данные.

Добавлено через 1 минуту
вот мой вариант без дополнительных флагов.
C#
1
2
3
4
5
6
7
   private static long Op(int[] x)
        {
            long m = 0;
            for (int i = 1; m == 0 || x[i] != 0; ++i)
                if (x[i] != 0) { if (m == 0 && x[i-1] == 0) ++m; m *= x[i]; }
            return m;
        }
Добавлено через 4 минуты
andrew_w2k, нее все ок. К тебе претензий вообще нет, ты дал правильные ответы, а то что задачу можно решать 100500 различными способами, так это прикольно. Просто с Linq меня временами бесит(особенно на работе), трудно сходу оценить сложность решения.
0
kontuPauk
300 / 298 / 66
Регистрация: 29.01.2013
Сообщений: 638
Записей в блоге: 1
Завершенные тесты: 1
03.03.2013, 10:40 #12
Да сказано было без претензий и не о личностях. Просто таки меня по-другому учили. Был преподаватель, который любил поменять входные данные. Да и пятнадцать лет практики заставляли. Ладно, без претензий.
0
03.03.2013, 10:40
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.03.2013, 10:40
Привет! Вот еще темы с ответами:

Вычислить произведение элементов массива, расположенных между первым и вторым нулевыми элементами - C#
Помогите решить задачу на с#, произведение элементов массива, расположенных между первым и вторым нулевыми элементами.

Найти номер максимального элемента массива и произведение элементов, между первым и вторым нулевыми элементами - C#
Помогите, пожалуйста, написать программу. Вот само задание: В одномерном массиве, состоящем из n целочисленных элементов,...

Найти сумму элементов массива, расположенных между первым и вторым отрицательными элементами - C#
Привет всем умным мальчикам!)) очень нужна ваша помощь! решите пожалуйста задачки 1)В одномерном массиве, состоящем из я вещественных...

Найти сумму элементов массива, расположенных между первым и вторым положительными элементами - C#
Здравствуйте. Искал на форуме похожие темы и нашел. Но что-то не могу их применить к своей задаче. Задание: Найти сумму элементов...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru