tteplovoz3789
?>

На с#, ! ввести одномерный массив, вывести его. выяснить, какое число в массиве встретится ранее – положительное или отрицательное (нули не рассматривать если положительное – найти в массиве максимальный элемент и возвести его в квадрат, если отрицательное – возвести в квадрат минимальный элемент.

Информатика

Ответы

Бернард pokerman
Int num = 0;           
Console.WriteLine("Введите элементы массива через пробел:");           
String[] array = Console.ReadLine().Replace("  "," ").Split();           
Int32[] numbers = new Int32[array.Length];           
Console.Write("Массив: [");           
for (int i = 0; i < numbers.Length; i++)           
{               
Console.Write(array[i]);               
if(i!=numbers.Length-1)                   
Console.Write(", ");               
numbers[i] = Int32.Parse(array[i]);               
if (num == 0)                   
num = numbers[i];           
}           
Console.Write("]\n");           
if (num > 0)               
Console.WriteLine("Максимальное число в квадрате: {0}",Math.Pow(numbers.Max(), 2));           
else
Console.WriteLine("Минимальное число в квадрате: {0}",Math.Pow(numbers.Min(), 2));           
Console.WriteLine("\nНажмите любую клавишу чтобы выйти...");            Console.ReadKey();
На с#, ! ввести одномерный массив, вывести его. выяснить, какое число в массиве встретится ранее – п
Дарья16
Чтобы прекратить ввод чисел в массив нужно ввести число "-1".
class ArrayMiddle{
 public static void main(String args[]){
  java.util.Scanner in = new java.util.Scanner(System.in); long eArray[] = new long[1];
  while((eArray[eArray.length-1] = in.nextLong())!=-1){
   long nArray[] = new long[eArray.length+1];
   for(int nCell = 0; nCell<eArray.length; nCell++)nArray[nCell]=eArray[nCell];
   eArray = nArray;
  } eArray[eArray.length-1] = 0;
  for(int cCell = 0; cCell<eArray.length-1; cCell++)eArray[eArray.length-1]+=eArray[cCell];
  System.out.print(eArray[eArray.length-1]/(double)(eArray.length-1));
 }
}
topsalon
Собственно, решение однострочное...

// PascalABC.NET 3.0, сборка 1150 от 22.01.2016
begin
  Writeln('Ср.арифм=',ArrRandom(30,0,1000).Println(', ').
      Where(x->Odd(x)).Average)
end.

Тестовое решение:
611, 443, 634, 637, 44, 297, 286, 431, 130, 767, 388, 513, 827, 681, 619, 810, 586, 697, 206, 823, 294, 238, 354, 138, 411, 141, 873, 864, 715, 564
Ср.арифм=592.875

И пояснение, как это работает, т.е. по сути алгоритм на русском языке.
ArrRandom(30,0,1000) создает массив из 30 элементов и заполняет его случайными значениями из диапазона [0,1000]. Далее этот массив обрабатывается методом Println, который направляет значения элементов на вывод, разделяя их запятой с последующим пробелом и в конце вывода добавляет смену строки. Затем элементы массива проходят фильтр Where(x->Odd(x)), который пропускает через себя только те значения, которые удовлетворяют условию Odd(значение элемента)=True, а мы знаем, что Odd() возвращает True для нечетного аргумента. Далее фильтр элементы обрабатываются методом Average, который умеет принимать набор значений и возвращать их среднее. И наконец, процедура Writeln выводит полученное значение, предваряя его текстовым пояснением.

Ответить на вопрос

Поделитесь своими знаниями, ответьте на вопрос:

На с#, ! ввести одномерный массив, вывести его. выяснить, какое число в массиве встретится ранее – положительное или отрицательное (нули не рассматривать если положительное – найти в массиве максимальный элемент и возвести его в квадрат, если отрицательное – возвести в квадрат минимальный элемент.
Ваше имя (никнейм)*
Email*
Комментарий*

Популярные вопросы в разделе

rayman777
rayon14
krispel9
mnkrasnova
VladimirovnaKashintsev1151
Как выделяется тело документа?
re-art
sanina611
sergeystepanov231
s777tver109
shymilin19951783
LYuBOV
dashanna04225
Виталий_Ильназ574
Koranna1986
stratocasterr34