Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- using System;
- using System.Collections;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- namespace vk_ol9
- {
- class Program
- {
- static void select_sort(double[] a, int length)
- {
- //в цикле до предпоследнего элемента
- for (int i = 0; i < length - 1; i++)
- {
- int min_i = i;/* устанавливаем начальное значение минимального индекса */
- for (int j = i + 1; j < length; j++)/* находим индекс минимального элемента */
- {
- //если модуль текущего элемента меньше модуля минимально
- if (Math.Abs(a[j]) < Math.Abs(a[min_i]))
- {
- //индекс текущего присваиваем индексу минимального
- min_i = j;
- }
- }
- double temp = a[i];/* меняем значения местами */
- a[i] = a[min_i];
- a[min_i] = temp;
- }
- }
- //вывод данных массива
- static void print(double[] mas)
- {
- Console.WriteLine("Данные в массиве:\n");
- for (int i = 0; i < mas.Length; i++)
- Console.Write(" {0:F4} ", mas[i]);
- Console.WriteLine("\n");
- }
- static void Main(string[] args)
- {
- Random rand = new Random();
- Console.WriteLine("Введите размер массива");
- int n = int.Parse(Console.ReadLine());
- double sum = 0;
- double min;
- int firstMinus = -1, secondMinus = -1;
- int positinoMin=0;
- double[] mas = new double[n];
- for (int i = 0; i < n; i++)//заполняем массив
- {
- mas[i] = rand.NextDouble();
- if (rand.NextDouble() >= 0.5)//делаем число больше 1 с вероятностью 50%
- {
- mas[i] += rand.Next(10);
- }
- if (rand.NextDouble() >= 0.5)//делаем число отрицательным с вероятностью 50%
- {
- mas[i] *= -1;
- }
- }
- print(mas);//вывод массива на экран
- min = mas[0];
- for(int i=0;i<n;i++)
- if (mas[i] < min)
- {
- min = mas[i];
- positinoMin = i;
- }
- Console.WriteLine("Номер минимального элмента{0}, значение = {1}", min, positinoMin);
- for (int i = 0; i < n; i++)
- {
- if (mas[i] < 0 && firstMinus == -1)
- {
- firstMinus = i;
- continue;
- }
- if (mas[i] < 0 && secondMinus == -1 && firstMinus!=-1)
- secondMinus = i;
- if (firstMinus != -1 && secondMinus != -1)
- break;
- }
- if (firstMinus == -1 || secondMinus == -1)
- {
- Console.WriteLine("Посчитать сумму не возможно.Слишком мало отрицательных элементов");
- }
- else
- {
- for (int i = firstMinus; i < secondMinus; i++)
- sum += mas[i];
- Console.WriteLine("Сумма между первыми двумя отрицательными элементами равна " + sum);
- }
- select_sort(mas, n);
- Console.WriteLine("Результат сортировки\n");
- print(mas);
- Console.WriteLine("\nДля продожения нажмите любую клавишу\n");
- Console.ReadLine();
- }
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement