Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/13: Рейтинг темы: голосов - 13, средняя оценка - 4.85
5 / 5 / 2
Регистрация: 12.11.2010
Сообщений: 56

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

25.04.2011, 20:12. Показов 2661. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго вам товарищи! Возникла небольшая проблемка с работой над массивами в С#. Есть две задачи,вот условие:
1.Дан вектор A(n). Поменять местами первый четный элемент вектора с последним нечетным элементом.
2.Дан целочисленный вектор A(n). Найти произведение нечетных элементов, имеющих четный индекс.
В первой задаче абсолютно не могу работать с индексами(подскажите как найти их по условию).
По второй задаче есть наработки, но считает не правильно, помогите разобраться где ошибка.ВОт код второй задачи:
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
 
namespace ConsoleApplication8
{
    class Program
    {
        static void Main(string[] args)
        {
            int n,p,p1;
            n = 0;
            p = 0;
            p1 = 1;
            Console.WriteLine("Введите размер массива:");
            string buf = Console.ReadLine();
            n = int.Parse(buf);
            p = int.Parse(buf);
            p1 = int.Parse(buf);
            int[] a = new int[n];
            
            Console.WriteLine("Введите элементы массива:");
            string b;
            for (int i = 0; i < n; i++)
            {
                b = Console.ReadLine();
                a[i] = int.Parse(b);
            }
                for (int i = 0; i < n; i++)
                {
                    Console.Write("\t" + a[i]);
                    Console.WriteLine();
                }
           //
            for (int i = 0; i < n;i++)
            {
               
                if (i / 2 == 0)
                {
                    p = i;
                }
                if (a[i] / 2 != 0)
                    p1 = a[i] * p;
             }
            Console.WriteLine("Произведение:"+p1);
              
           Console.ReadLine();        
        }
    }
}
1
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.04.2011, 20:12
Ответы с готовыми решениями:

Массив: поменять местами первый минимальный с первым элементом массива, а максимальный элемент - с последним
первый минимальный с первым элементом массива поменять местами ,а максимальный элемент с последним элементом массива. вот как тут делать ?...

В каждом столбце массива А поменять местами первый отрицательный элемент с последним элементом столбца
В каджом столбце массива А поменять местами первый отрицательный элемент с последним элементом столбца. Матица задана помогите ...

В каджом столбце массива А поменять местами первый отрицательный элемент с последним элементом столбца.
Дан двумерный числовой массив А . Составить программу, реализующую следующие действия: 1. В каджом столбце массива А поменять...

3
36 / 24 / 3
Регистрация: 05.01.2010
Сообщений: 37
25.04.2011, 21:22
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

В первой задаче у нас всего навсего нужно поменять 2 элемента местами. Сначала мы ищем их индексы, а потом меняем.
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
using System;
 
namespace ConsoleApplication3
{
    class Program
    {
        static void Main()
        {
            Console.Write("Enter size: ");
            int size = int.Parse(Console.ReadLine());
            int[] array = new int[size];
            Random r = new Random();
            for(int i = 0; i<array.Length; ++i)
            {
                array[i] = r.Next(100);
                Console.Write(array[i] + "\t");
            }
 
                        int index_first=-1, index_last=-1;
            for (int i = 0; i < array.Length; ++i)
            {
                if (array[i] % 2 == 0 && index_first == -1)
                    index_first = i;
                if (array[i] % 2 == 1)
                    index_last = i;
            }
 
            if (index_first >= 0 && index_last >= 0)
            {
                Console.WriteLine("Changing");
                int t = array[index_first];
                array[index_first] = array[index_last];
                array[index_last] = t;
            }           
 
            Console.WriteLine();
            for (int i = 0; i < array.Length; ++i )
                Console.Write(array[i] + "\t");
            Console.ReadKey();
        }
    }
}
Во второй задаче решается таким образом:
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
using System;
 
namespace ConsoleApplication3
{
    class Program
    {
        static void Main()
        {
            Console.Write("Enter size: ");
            int size = int.Parse(Console.ReadLine());
            int[] array = new int[size];
            Random r = new Random();
            for (int i = 0; i < array.Length; ++i)
            {
                array[i] = r.Next(10);
                Console.Write(array[i] + "\t");
            }
 
            int p = 1;
            for (int i = 1; i < array.Length; i+=2)
            {
                if (array[i] % 2 == 1)
                    p *= array[i];
            }
 
            Console.WriteLine("\nP = {0}", p);
            Console.ReadKey();
        }
    }
}
2
5 / 5 / 2
Регистрация: 12.11.2010
Сообщений: 56
25.04.2011, 22:02  [ТС]
Ооо,спасибо большое! Даже через класс Array написано, очень признателен)
1
36 / 24 / 3
Регистрация: 05.01.2010
Сообщений: 37
25.04.2011, 22:14
Не за что
Только огорчу. Это так массив называется. Тут и такого хватит, я думаю, но если нужно переделать, это не будет проблемой
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.04.2011, 22:14
Помогаю со студенческими работами здесь

В одномерном массиве первый элемент поменять местами с последним элементом, второй элемент с предпоследним элементом и так далее
В одномерном массиве первый элемент поменять местами с последним элементом, второй элемент с предпоследним элементом и так далее.

Массив: В одномерном массиве первый элемент поменять местами с последним элементом, второй элемент с предпоследним элементом и так далее.
В одномерном массиве первый элемент поменять местами с последним элементом, второй элемент с предпоследним элементом и так далее.

Обменять первый четный с последним нечетным элементом в массиве
Необходимо обменять местами первый четный и последний нечетный элемент массива. Как это сделать . С первым четным элементом не могу...

Поменять местами первый отрицательный элемент с последним положительным элементом
Дан массив Х(10) Поменять местами первый отрицательный элемент, с последним положительным элементом.

Поменять местами первый отрицательный элемент с последним положительным элементом массива
Одномерный массив. Дан массив Х(10). Поменять местами первый отрицательный элемент с последним положительным элементом. Заполнение...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Как дизайн сайта влияет на конверсию: 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 На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru