0 / 0 / 0 Регистрация: 08.10.2014 Сообщений: 44 |
|
1 |
|
Как вывести нечетные индексы в массиве?05.12.2014, 18:17. Показов 7992. Ответов 2
как вывести нечетные индексы в массиве? то есть например: Выходные данные Примеры выходные данные
0 |
6805 / 4564 / 4817 Регистрация: 05.06.2014 Сообщений: 22,438 |
|
05.12.2014, 20:53 |
2 |
как вывести нечетные индексы в массиве? Необходимо вывести все элементы массива с чётными номерами. Что все-таки надо сделать?
0 |
ighor 15 / 15 / 21 Регистрация: 13.11.2014 Сообщений: 275 |
||||
05.12.2014, 22:46 |
3 |
|||
Сообщение было отмечено roma070201 как решение Решение
0 |
Массивы в 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.
Объявление переменной, создание и присвоение переменной ссылки массива могут быть объединены в одном операторе, как показано ниже:
dataType[] arrayRefVar = new dataType[arraySize];
В качестве альтернативы массивы в Java можно создавать следующим образом:
dataType[] arrayRefVar = {значение0, значение1, ..., значениеk};
Элементы массива доступны через индекс. Отсчет индексов ведется от 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 = {1.9, 2.9, 3.4, 3.5};
// Вывести на экран все элементы массива
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 = {1.9, 2.9, 3.4, 3.5};
// Вывести массив на экран
for (double element: myList) {
System.out.println(element);
}
}
}
Получим следующий результат:
1.9
2.9
3.4
3.5
Передача массива в метод
Также как можно передать значение примитивного типа в метод, можно также передать массив в метод. Например, следующий метод отображает элементы в 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:
printArray(new int[]{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 = {1, 3, 8, 10, 4};
// Массив 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 = {2.4, 3.8, 11.2, 9.8, 1.18};
// Вывод длины массива myArray1 на экран.
System.out.println("Количество элементов в массиве myArray1: " + myArray1.length);
// Массив myArray2 из 4 элементов типа String.
String[] myArray2 = {"Java", "массив", "пример", "proglang.su"};
// Вывод размера массива 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 = {11, 5.8, 11.1, 10.9};
// Переменной 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 = {11, 5.8, 11.1, 10.9};
// Переменной 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 = {11, 5.8, 11.1, 10.9};
// Переменной 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 = {11, 5.8, 11.1, 10.9};
// Переменной 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 = {2.5, 1.8, 1.3, 6.5, 22.8};
// Инициализируем переменную 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 = {2.5, 1.8, 1.3, 6.5, 22.8};
// Инициализируем переменную total.
double total = 0;
// Прибавляем к переменной total каждый элемент массива с помощью улучшенного цикла for.
for(double element : myList) {
total += element;
}
// Вывод результата на экран.
System.out.println("Сумма массива myList: " + total);
}
}
Получим следующий результат:
Сумма массива myList: 34.9
Пример 6: вывод массива
В данном примере рассмотрим как вывести массив на экран в Java.
public class Test {
public static void main(String[] args) {
// Вывод на экран массива myArray из 5 элементов типа double.
double[] myList = {11.5, 1.9, 5.32, 8.8, 15.8};
// Вывод массива на экран с помощью улучшенного цикла 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 = {2, 2.7, 3, 12, 23.8};
// Вывод четных элементов массива на экран.
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 = {11.5, 1.9, 5.32, 8.8, 15.8};
// Вывод элементов массива с четным индексом на экран.
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,
What I want to do is, given an array, select the items which have even/odd index insite the list.
I’ll explain better: if I have an array like this [1,4,6,2,8]
, I want to add to a list (evenList
) all the items which have even position
(position zero, two, four, etc.) in the array (in this case 1,6,8
).
Same thing for the odd items.
I have the developed the following code but I am stuck.
class CheckItem
{
static readonly string myNumber = "5784230137691";
static int[] firstTwelveList = new int[12];
static int[] arrayEvenPosition = new int[(myNumber.Length / 2)];
static int[] arrayOddPosition = new int[(myNumber.Length / 2)];
static readonly int idx = 0;
public static void Position()
{
firstTwelveList = myNumber.Substring(0, 12).Select(c => c - '0').ToArray();
foreach (var even in firstTwelveList)
{
if(Array.IndexOf(firstTwelveList, idx) % 2 == 0) //never enter here...
{
Array.Copy(firstTwelveList, arrayEvenPosition, (myNumber.Length / 2));
}
}
Console.ReadLine();
}
}
What I expect is that the arrayEvenPosition
will contain 5,8,2,0,3,6,1
and arrayOddPosition
7,4,3,1,7,9
Да в общем-то как обычно: вводим переменную, которую сравниваем со всеми элементами в цикле.
void Main()
{
int[] arrayONe = { 0, 1, 3, 9, 10, 4, 2, -4 };
var firstMinElement = this.GetFirstEvenMinimumValue(arrayONe);
Console.WriteLine(firstMinElement);
}
// Define other methods and classes here
public int GetFirstEvenMinimumValue(int[] arr)
{
if (arr.Length < 2)
throw new Exception("Array is too short");
var min = arr[1];
for (int i = 0; i < arr.Length; i++)
{
if (i % 2 == 0)
continue;
if (arr[i] < min )
min = arr[i];
}
return min;
}
Кстати, действительно: можно ещё изящнее:
public int GetFirstEvenMinimumValue(int[] arr)
{
if (arr.Length < 2)
throw new Exception("Array is too short");
var min = arr[1];
for (int i = 3; i < arr.Length; i+=2)
{
if (arr[i] < min )
min = arr[i];
}
return min;
}
(Вариант предложен @Lunar Whisper в комментариях)
Другие ответы верны, что есть более простые способы разбить массив на два массива на основе индекса (нечетный / четный). Однако я заметил, что в вашем коде есть две проблемы.
if (Array.IndexOf(firstTwelveList, idx) % 2 == 0) //never enter here..
Два параметра для IndexOf – это массив и элемент, по которому вы хотите найти индекс элемента, idx не является правильным параметром. это должна быть переменная even из цикла foreach
Во-вторых, копируя правильное значение в другой массив, вы копируете в новый массив первые 6 символов 1-го массива.
Цитируя справочные документы Array.Copy (массив, массив, Int32), он просто копирует требуемый диапазон элементов из первого массива во второй массив.
Поэтому вам нужно изменить код, чтобы скопировать элемент, удовлетворяющий условию четный / нечетный. для этого вам нужна переменная для отслеживания текущего индекса нового массива
Таким образом можно изменить весь класс
class CheckItem
{
static readonly string myNumber = "5784230137691";
static int[] firstTwelveList = new int[12];
static int[] arrayEvenPosition = new int[(myNumber.Length / 2)];
static int[] arrayOddPosition = new int[(myNumber.Length / 2)];
static int idx = 0;
static int evenIdx = 0; // track current index of new array
public static void Position()
{
firstTwelveList = myNumber.Substring(0, 12).Select(c => c - '0').ToArray();
foreach (var even in firstTwelveList)
{
if (Array.IndexOf(firstTwelveList, even) % 2 == 0) // replace idx with even...
{
Array.Copy(firstTwelveList, idx, arrayEvenPosition, evenIdx, 1); // copy the element from the current index of first array to new array
evenIdx++;
}
idx++;
}
Console.ReadLine();
}
}