Переместить в первую половину массива элементы а четными индексами, во вторую с нечетными - C#
Формулировка задачи:
Здравствуйте. Нужна помощь.
Полное условие: В одномерном массиве, состоящем из n целочисленных элементов, вычислить:
1. минимальный по модулю элемент массива;
2. сумму модулей элементов массива, расположенных после первого элемента,
равного нулю.
Преобразовать массив таким образом, чтобы в первой его половине
располагались элементы, стоявшие в четных позициях, а во второй
половине - элементы, стоявшие в нечетных позициях.
Код:
Первый два пункта сделаны. Как преобразовать массив таким образом не знаю.
Листинг программы
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- namespace ConsoleApplication3
- {
- class Program
- {
- public static void Main()
- {
- Console.Write("Введите размер массива: ");
- int n = Convert.ToInt32(Console.ReadLine());
- int[] array = new int[n];
- Random rand = new Random((int)DateTime.Now.Ticks);
- for (int i = 0; i < n; i++)
- {
- array[i] = rand.Next(-10, 10);
- Console.Write(array[i] + " ");
- }
- var modules = from num in array
- select Math.Abs(num);
- double min = modules.Min();
- Console.WriteLine("Минимальный по модулю: " + min);
- bool z = false;
- double sum = 0;
- for (int i = 0; i < array.Length; i++)
- {
- if (array[i] == 0.0)
- z = true;
- if (z == true)
- sum += array[i];
- }
- Console.WriteLine("Сумма чисел после нуля: " + sum);
- Console.ReadKey();
- }
- }
- }
Решение задачи: «Переместить в первую половину массива элементы а четными индексами, во вторую с нечетными»
textual
Листинг программы
- b[i] = i < med ? array[i * 2 + 1] : array[(i - med) * 2];
ИИ поможет Вам:
- решить любую задачу по программированию
- объяснить код
- расставить комментарии в коде
- и т.д