Java вывести нечетные числа массива

Массивы

Массивы в Java — это структура данных, которая хранит упорядоченные коллекции фиксированного размера элементов нужного типа. В Java массив используется для хранения коллекции данных, но часто бывает полезно думать о массиве как о совокупности переменных одного типа.

Вместо объявления отдельных переменных, таких как number0, number1, . и number99, Вы объявляете одну переменную массива, например, numbers и используете numbers[0], numbers[1], . и numbers[99], для отображения отдельных переменных.

Данная статья ознакомит Вас как в Java объявить массив переменных, создать и обрабатывать массив с помощью индексированных переменных.

Объявление массива

Чтобы использовать массив в программе, необходимо объявить переменную для ссылки на массив, и Вы должны указать тип массива, который может ссылаться на переменную. Синтаксис для объявления переменной массива:

dataType[] arrayRefVar; // Предпочтительный способ. или dataType arrayRefVar[]; // Работает, но не является предпочтительным способом. 

Примечание: стиль dataType[] arrayRefVar является предпочтительным. Стиль dataType arrayRefVar[] происходит из языка C/C++ и был принят в Java для C/C++-программистов.

Пример

Следующие фрагменты кода примеры использования данного синтаксиса:

double[] myList; // Предпочтительный способ. или double myList[]; // Работает, но не является предпочтительным способом. 

Создание массива

В Java создать массив можно с помощью оператора new с помощью следующего синтаксиса:

arrayRefVar = new dataType[arraySize]; 

Вышеуказанное объявление делает две вещи:

  • Создает массив, используя new dataType[arraySize];
  • Ссылка на недавно созданный массив присваивается переменной arrayRefVar.
Читайте также:  Python дополнение строки нулями

Объявление переменной, создание и присвоение переменной ссылки массива могут быть объединены в одном операторе, как показано ниже:

dataType[] arrayRefVar = new dataType[arraySize]; 

В качестве альтернативы массивы в Java можно создавать следующим образом:

Элементы массива доступны через индекс. Отсчет индексов ведется от 0; то есть они начинают от 0 и до arrayRefVar.length-1.

Пример

Следующий оператор объявляет массив переменных myList, создает массив из 10 элементов типа double и присваивает ссылку myList:

double[] myList = new double[10]; 

Изображение отображает массив myList. Здесь myList имеет десять значений double и индексы от 0 до 9.

Массивы

Работа с массивами

При работе с элементами массива, часто используют цикл for или цикл foreach потому, что все элементы имеют одинаковый тип и известный размер.

Пример

Полный пример, показывающий, как создавать, инициализировать и обработать массив:

public class TestArray < public static void main(String[] args) < double[] myList = ; // Вывести на экран все элементы массива for (int i = 0; i < myList.length; i++) < System.out.println(myList[i] + " "); >// Сумма элементов массива double total = 0; for (int i = 0; i < myList.length; i++) < total += myList[i]; >System.out.println("Сумма чисел массива: " + total); // Нахождение среди элементов массива наибольшего double max = myList[0]; for (int i = 1; i < myList.length; i++) < if (myList[i] >max) max = myList[i]; > System.out.println("Наибольший элемент: " + max); > > 

Получим следующий результат:

1.9 2.9 3.4 3.5 Сумма чисел массива: 11.7 Наибольший элемент: 3.5 

Цикл foreach

JDK 1.5 представила новый цикл for, известный как цикл foreach или расширенный цикл for, который позволяет последовательно пройти весь массив без использования индекса переменной.

Пример

Следующий код отображает все элементы в массиве myList:

public class TestArray < public static void main(String[] args) < double[] myList = ; // Вывести массив на экран for (double element: myList) < System.out.println(element); >> > 

Получим следующий результат:

Передача массива в метод

Также как можно передать значение примитивного типа в метод, можно также передать массив в метод. Например, следующий метод отображает элементы в int массиве:

public static void printArray(int[] array) < for (int i = 0; i < array.length; i++) < System.out.print(array[i] + " "); >> 

Его можно вызвать путем передачи массива. Например, следующий оператор вызывает метод printArray для отображения 3, 1, 2, 6, 4 и 2:

Возврат массива из метода

Метод может также возвращать массив. Например, метод, показанный ниже, возвращает массив, который является реверсирование другого массива:

public static int[] reverse(int[] list) < int[] result = new int[list.length]; for (int i = 0, j = result.length - 1; i < list.length; i++, j--) < result[j] = list[i]; >return result; > 

Методы для массива

Класс java.util.Arrays содержит различные статические методы для поиска, сортировки, сравнения и заполнения элементов массива. Методы перегружаются для всех примитивных типов.

Описание
1 public static int binarySearch(Object[] a, Object key)
Ищет заданный массив объектов (byte, int, double, и т.д.) для указанного значения, используя алгоритм двоичного поиска. Массив должен быть отсортирован до выполнения этого вызова. Это возвращает индекс ключа поиска, если он содержится в списке; в противном случае (-(точка вставки + 1).
2 public static boolean equals(long[] a, long[] a2)
Возвращает значение true, если два указанных массивах равны друг другу. Два массива считаются равными, если оба массива содержат одинаковое количество элементов, и все соответствующие пары элементов в двух массивах равны. Такой же метод может быть использован всеми другими примитивными типами данных (byte, short, int и т.д.).
3 public static void fill(int[] a, int val)
Присваивает определенное значение int к каждому элементу указанного целочисленного массива. Такой же метод может быть использован всеми другими примитивными типами данных (byte, short, int и т.д.).
4 public static void sort(Object[] a)
Этот метод сортировки сортирует указанный массив объектов в порядке возрастания, в соответствии с естественным порядком его элементов. Такой же метод может быть использован всеми другими примитивными типами данных (byte, short, int и т.д.).

Пример 1: создание, объявление переменных, определение (выделение памяти) и инициализация массива

В качестве примера возьмем тип данных int. Вы же можете использовать любой другой тип данных.

public class Test < public static void main(String[] args) < // Создание массивов myArrayInt1 и myArrayInt2 типа int и объявление переменных int[] myArrayInt1; int myArrayInt2[]; // Определение массива или выделение памяти // Массив myArrayInt3 из 10 элементов с начальным значением 0 для каждого элемента int[] myArrayInt3; myArrayInt3 = new int[10]; // Массив myArrayInt4 из 20 элементов с начальным значением 0 для каждого элемента int[] myArrayInt4 = new int[20]; //Инициализация массива // Массив myArrayInt5 из 5 элементов со значениями элементов 1, 3, 8, 10, 4 int[] myArrayInt5 = ; // Массив myArrayInt6 из 10 элементов с начальным значением 0 для каждого элемента int[] myArrayInt6 = new int[10]; // Присвоение второму элементу myArrayInt6 значения 14 myArrayInt6[2] = 14; // Присвоение пятому элементу myArrayInt6 значения 8 myArrayInt6[5] = 8; > > 

Пример 2: длина массива

Узнать размер массива в Java можно с помощью метода length(). Данный метод позволяет определить размерность массива.

public class Test < public static void main(String[] args) < // Массив myArray1 из 5 элементов типа double. double[] myArray1 = ; // Вывод длины массива myArray1 на экран. System.out.println("Количество элементов в массиве myArray1: " + myArray1.length); // Массив myArray2 из 4 элементов типа String. String[] myArray2 = ; // Вывод размера массива myArray2 на экран. System.out.println("Количество элементов в массиве myArray2: " + myArray2.length); > > 

Получим следующий результат:

Количество элементов в массиве myArray1: 5 Количество элементов в массиве myArray2: 4 

Пример 3: максимальный элемент массива

Простые способы для того, чтобы найти максимальное число в массиве в Java. Сперва воспользуемся методом Math.max().

public class Test < public static void main(String[] args) < // Нахождение максимального элемента в массиве myArray из 4 элементов типа double. double[] myArray = ; // Переменной max задаем минимальное double-значение. double max = Double.MIN_VALUE; // Перебираем все элементы массива. for (int i = 0; i < myArray.length; i++) < // Переменной max с помощью метода Math.max() присваиваем максимальное значение // путем выбора наибольшего из двух значений ("старого" значения max и значения элемента). max = Math.max(max, myArray[i]); >// Выводим на экран наибольшее число массива myArray. System.out.println("Максимальный элемент в массиве myArray: " + max); > > 

Получим следующий результат:

Максимальный элемент в массиве myArray: 11.1 

Ещё один пример нахождения максимального числа в массиве в Java. Здесь мы не будем использовать какие-либо методы.

public class Test < public static void main(String[] args) < // Нахождение максимального значения в массиве myArray из 4 элементов типа double. double[] myArray = ; // Переменной max задаем значение нулевого элемента. double max = myArray[0]; // Перебираем все элементы массива. for (int i = 1; i < myArray.length; i++) < // Сравниваем значение переменной max со значениями элемента массива. // Если значение элемента массива больше значения переменной max, // то новое значение переменной max будет равно значению этого элемента. if (myArray[i] >max) < max = myArray[i]; >> // Выводим на экран наибольший элемент массива myArray. System.out.println("Максимальное значение в массиве myArray: " + max); > > 

Получим следующий результат:

Максимальное значение в массиве myArray: 11.1 

Пример 4: минимальный элемент массива

Написанный ниже код практически ничем не отличается от кода, описанного в примере 3. Он в точности наоборот, просто здесь мы ищем минимальное число в массиве в Java. В первом способе воспользуемся методом Math.min().

public class Test < public static void main(String[] args) < // Нахождение минимального элемента в массиве myArray из 4 элементов типа double. double[] myArray = ; // Переменной min задаем максимальное double-значение. double min = Double.MAX_VALUE; // Перебираем все элементы массива. for (int i = 0; i < myArray.length; i++) < // Переменной min с помощью метода Math.min() присваиваем минимальное значение // путем выбора наименьшего из двух значений ("старого" значения min и значения элемента). min = Math.min(min, myArray[i]); >// Выводим на экран наименьшее число массива myArray. System.out.println("Минимальный элемент в массиве myArray: " + min); > > 

Получим следующий результат:

Минимальный элемент в массиве myArray: 5.8 

Ещё один пример нахождения максимального числа в массиве в Java. Здесь мы не будем использовать какие-либо методы.

public class Test < public static void main(String[] args) < // Нахождение минимального значения в массиве myArray из 4 элементов типа double. double[] myArray = ; // Переменной min задаем значение нулевого элемента. double min = myArray[0]; // Перебираем все элементы массива. for (int i = 1; i < myArray.length; i++) < // Сравниваем значение переменной min со значениями элемента массива. // Если значение элемента массива меньше значения переменной min, // то новое значение переменной min будет равно значению этого элемента. if (myArray[i] < min) < min = myArray[i]; >> // Выводим на экран наименьший элемент массива myArray. System.out.println("Минимальное значение в массиве myArray: " + min); > > 

Получим следующий результат:

Минимальное значение в массиве myArray: 5.8 

Пример 5: сумма массива

В этом примере рассмотрим как получить сумму элементов массива в Java.

public class Test < public static void main(String[] args) < // Нахождение суммы элементов в массиве myArray из 5 элементов типа double. double[] myList = ; // Инициализируем переменную total. double total = 0; // Прибавляем к переменной total каждый элемент массива. for (int i = 0; i < myList.length; i++) < total += myList[i]; >// Вывод результата на экран. System.out.println("Сумма элементов массива myList: " + total); > > 

Получим следующий результат:

Сумма элементов массива myList: 34.9 

А в этом примере используем улучшенный цикл for, чтобы найти сумму массива.

public class Test < public static void main(String[] args) < // Получение суммы элементов в массиве myArray из 5 элементов типа double. double[] myList = ; // Инициализируем переменную total. double total = 0; // Прибавляем к переменной total каждый элемент массива с помощью улучшенного цикла for. for(double element : myList) < total += element; >// Вывод результата на экран. System.out.println("Сумма массива myList: " + total); > > 

Получим следующий результат:

Пример 6: вывод массива

В данном примере рассмотрим как вывести массив на экран в Java.

public class Test < public static void main(String[] args) < // Вывод на экран массива myArray из 5 элементов типа double. double[] myList = ; // Вывод массива на экран с помощью улучшенного цикла for. System.out.print("Вывод элементов массива myList: "); for(double element : myList) < System.out.print(element + ", "); >// Вывод элементов массива на экран. System.out.print("\nВывод элементов массива myList: "); for (int i = 0; i < myList.length; i++) < System.out.print(myList[i] + ", "); >> > 

Получим следующий результат:

Вывод элементов массива myList: 11.5, 1.9, 5.32, 8.8, 15.8, Вывод элементов массива myList: 11.5, 1.9, 5.32, 8.8, 15.8, 

Пример 7: вывод четных и нечетных элементов массива

В примере показано как вывести четные и нечетных элементы массива в Java.

public class Test < public static void main(String[] args) < // Массива myArray из 5 элементов типа double. double[] myList = ; // Вывод четных элементов массива на экран. System.out.print("Четные элементы массива myList: "); for (int i = 0; i < myList.length; i++) < if(myList[i]%2 == 0)< System.out.print(myList[i] + ", "); >> // Вывод нечетных элементов массива на экран. System.out.print("\nНечетные элементы массива myList: "); for (int i = 0; i < myList.length; i++) < if(myList[i]%2 != 0)< System.out.print(myList[i] + ", "); >> > > 

Получим следующий результат:

Четные элементы массива myList: 2.0, 12.0, Нечетные элементы массива myList: 2.7, 3.0, 23.8, 

Пример 8: вывод элементов массива с четным и нечетным индексом

В примере показано как вывести на экран элементы массива с четным и нечетным индексом.

public class Test < public static void main(String[] args) < // Массив myArray из 5 элементов типа double. double[] myList = ; // Вывод элементов массива с четным индексом на экран. System.out.print("Элементы массива myList с четным индексом: "); for (int i = 0; i < myList.length; i++) < if(i%2 == 0)< System.out.print("индекс " + i + " = " + myList[i] + ", "); >> // Вывод элементов массива с нечетным индексом на экран. System.out.print("\nЭлементы массива myList с нечетным индексом: "); for (int i = 0; i < myList.length; i++) < if(i%2 != 0)< System.out.print("индекс " + i + " = " + myList[i] + ", "); >> > > 

Получим следующий результат:

Элементы массива myList с четным индексом: индекс 0 = 11.5, индекс 2 = 5.32, индекс 4 = 15.8, Элементы массива myList с нечетным индексом: индекс 1 = 1.9, индекс 3 = 8.8, 

Источник

Нечетные числа

А у меня выводит 3,5,7,3,
подскажите как удалить запятую в конце
Задание:
Напишите метод printOddNumbers, который принимает массив и выводит в консоль только нечетные числа из него, через запятую. Конец вывода должен перевести курсор на новую строку.

Отсортировать нечетные числа по убыванию
отсортировать нечетные числа по убыванию (четные оставить на своих местах), не пойму почему не.

Двойной факториал + четные нечетные числа
Задача. Описать функцию Fact2(N) целого типа, вычисляющую значение "двойного факториала".

Вывести четные числа в порядке возрастания их индексов, а затем — все нечетные числа в порядке убывания их индексов
Пожалуйста помогите с решением данных задач Дан целочисленный массив размера N. Вывести вначале.

Вывести все содержащиеся в данном массиве нечетные числа в порядке возрастания их индексов, а также их количество
Пожалуйста помогите с решением данных задач Дан целочисленный массив размера N. Вывести все.

В массив B записать все четные числа из заданного целочисленного одномерного массива A, а в массив С — нечетные
Заполнить массивы B и C, переписав в массив B все четные числа из заданного целочисленного.

Эксперт Java

ну, видимо, надо сначала найти все подходящие числа, а потом уже куда-то их выводить так, как тебе нужно

Источник

Оцените статью