Форум программистов, компьютерный форум, киберфорум
Наши страницы
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
Сет
46 / 46 / 9
Регистрация: 27.05.2014
Сообщений: 219
1

Создать массив из номеров нулевых элементов

01.07.2015, 21:57. Просмотров 1191. Ответов 9
Метки нет (Все метки)

Добрый вечер уважаемые. Начал изучать java, решаю задачи по ней.
В общем есть такая задача: В целочисленной последовательности есть нулевые элементы. Создать массив из номеров этих элементов.
Я реализовал данным образом:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
public class Task_2_array {
    public static void main(String[] args) {
        /**
         * Массив над которым будут проводиться вычисления
         */
        int[] arr = {2, 4, 0, 3, 3, 0, 0, 0, 9};
        calculate(arr);
    }
 
    private static int calculate(int[] arr) {
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == 0) {
                int result[] = {i};
            }
        }
        return 0;
    }
}
Однако чувствую, что обманываю по большому счету себя(в result[] попали не индексы массива, а переменная i из цикла). Вопрос, есть ли возможность из принятого массива(arr) вытащить сразу индексы для записи в result?
Прошу прощения за говнокод, если он таковым является.
Заранее спасибо.
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.07.2015, 21:57
Ответы с готовыми решениями:

Создать массив из 15 элементов (забить значениями в коде). Посчитать произведение элементов кратных числу 3
public class TaskOne { public static void main(String args ){ // Создать...

Создать стек из номеров записи
Создать стек из номеров записи. Организовать прямой доступ к элементам записи.

Создать массив из n элементов (с клавиатуры)
День добрый! Помогите пожалуйста организовать ввод кол-во элементов массива с...

2. Создать массив из 5 элементов (ввод с клавиатуры). Посчитать разность первого и последнего элемента массива
import java.util.*; public class TaskTwo { public static void main(String...

Создать двумерный массив, а затем отсортировать его в порядке возрастания суммы элементов строк
Всем привет!!! Помогите пожалуйста с этой задачкой кто чем сможет, за ранее...

9
PlumBoom
:)
134 / 134 / 31
Регистрация: 30.03.2013
Сообщений: 428
01.07.2015, 22:18 2
Сет, так подойдет?
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import java.util.ArrayList;
 
public class App  {
    private static int[] getArray(int ... nums) {
        ArrayList<Integer> arrNums = new ArrayList<>();
        for (int i = 0; i < nums.length; i++) {
            if (nums[i] == 0) arrNums.add(i);
        }
 
        int arr[] = new int[arrNums.size()];
 
        for (int i = 0; i < arrNums.size(); i++) arr[i] = arrNums.get(i);
 
        return arr;
    }
 
    public static void main(String[] args) {
        int arr[] = getArray(1, 2, 0, 4, 0, 6, 5, 0, 6, 0);
 
        for (int anArr : arr) System.out.print(anArr + " ");
    }
}
1
Сет
46 / 46 / 9
Регистрация: 27.05.2014
Сообщений: 219
01.07.2015, 22:23  [ТС] 3
PlumBoom, думаю да, по крайней мере логичнее намного) Сейчас только разберусь до конца)
1
PlumBoom
:)
134 / 134 / 31
Регистрация: 30.03.2013
Сообщений: 428
01.07.2015, 22:45 4
Лучший ответ Сообщение было отмечено Сет как решение

Решение

Сет, я использовал аргумент разной длины, т. е. при вызове функции указываю "сколько захочу" аргументов, т.е. передаю числовую последовательность... В функции getArray создал динамический массив (ведь мы не знаем сколько у нас нулей может быть), потом циклом обработал числовую послед-ть (если нашли ноль, то добавляем в конец списка (динамического массива) соответствующий индекс)... Далее, создаем сам массив по заданию размером списка, добавляем в него элементы из списка и возвращаем массив. В главной фунции перебираем полученный массив

Сет, еще, как вариант, без создания статического массива (т.е. используем только динамический)
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
import java.util.ArrayList;
 
public class App  {
    private static ArrayList<Integer> getArray(int ... nums) {
        ArrayList<Integer> arrNums = new ArrayList<>();
 
        for (int i = 0; i < nums.length; i++)
            if (nums[i] == 0) arrNums.add(i);
 
        return arrNums;
    }
 
    public static void main(String[] args) {
        ArrayList<Integer> arr = getArray(1, 2, 0, 4, 0, 6, 5, 0, 6, 0);
 
        for (int anArr : arr) System.out.print(anArr + " ");
    }
}
0
Сет
46 / 46 / 9
Регистрация: 27.05.2014
Сообщений: 219
01.07.2015, 22:45  [ТС] 5
PlumBoom, да, я разобрался уже) Спасибо) Действительно, логичнее в разы, ну и удобнее с использованием динамического массива)
1
PlumBoom
:)
134 / 134 / 31
Регистрация: 30.03.2013
Сообщений: 428
01.07.2015, 23:06 6
Сет, и еще, если параметр не изменяем (нет присваиваний, только чтение) в методе, то лучше объявить его как final:
Java
1
private static ArrayList<Integer> getArray(final int ... nums) { /* ... */ }
Это придаст прирост к производительности выполнения


Сет, вот написал еще вариант, но без динамического массива Используя счетчик
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public class App  {
    private static int[] getArray(final int ... nums) {
        int count = 0; // счетчик
 
        for (int num : nums) if (num == 0) count++; // считаем нули
 
        int arrNums[] = new int[count]; // создаем массив определенного размера
 
        count = -1;
 
        // заполняем массив
        for (int i = 0; i < nums.length; i++)
            if (nums[i] == 0) arrNums[++count] = i;
 
        return arrNums;
    }
 
    public static void main(String[] args) {
        int arr[] = getArray(1, 2, 0, 4, 0, 6, 5, 0, 6, 0);
 
        for (int anArr : arr) System.out.print(anArr + " ");
    }
}
1
ryadovoy
2 / 2 / 1
Регистрация: 21.07.2015
Сообщений: 38
10.08.2015, 11:42 7
PlumBoom, Добрый день, недавно изучаю java. Реализовал таким образом.
LeanJava.java
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
public class LeanJava {
    public static void main(String[] args) throws Exception {
        try {
            BufferedReader buffRead = new BufferedReader(new InputStreamReader(System.in));
            System.out.print("Введите длинну массива: ");
            int length = Integer.parseInt(buffRead.readLine());
            int[] arr = new int[length];
            for (int count = 0; count < length; count++){
                System.out.print("Введите " + (count+1) + "-й элемент массива: ");
                arr[count] = Integer.parseInt(buffRead.readLine());
            }
            System.out.println("Массив номеров нулевых элементов массива " + Arrays.toString(arr) +" равен "+ Arrays.toString(ZeroIndexesArr.getZeroIndexesArr(arr)));
        } catch (Exception e) {
            System.out.println("Введите положительную длинну массива!");
        }
    }
}


ZeroIndexesArr.java
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public class ZeroIndexesArr {
    
    //метод возвращает массив, состоящий из индексов нулевых элементов arr[]
    public static int[] getZeroIndexesArr (int[] arr){
        if (arr.length==0)return null;
        int count = 0;
        for (int i = 0; i < arr.length; i++){
            if (arr[i]==0) count++;
        }
        int[] zeroIndexesArr = new int[count];
        count = 0;
        for (int i = 0; i < arr.length; i++) {
            if ( arr[i]==0 ){
                zeroIndexesArr[count] = i+1;
                count++;
            }
        }
        return zeroIndexesArr; 
    }
}

Хочу ввод массива запихнуть в отдельный метод, что бы метод main был как можно меньше:
т.к решаю много мелких задач, а уже решенные хочу сохранить в проекте - на одну задачку один новый класс. Подскажите как это реализовать?
0
Ev[G]eN
iOS/Android Developer
Эксперт С++
5118 / 1556 / 950
Регистрация: 23.01.2011
Сообщений: 3,185
Завершенные тесты: 1
10.08.2015, 12:33 8
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
package ua.ev_g_en.cyberforum;
 
import java.io.IOException;
import java.util.Arrays;
import java.util.stream.IntStream;
 
public class Main {
    public static void main(String[] args) throws IOException {
        int[] array = { 1, 2, 4, 0, 5, 0, 4, 0, 2, 5, 0 };
        int[] result = IntStream.range(0, array.length).filter(index -> array[index] == 0).toArray();
        System.out.println(Arrays.toString(result));
    }
}
0
ryadovoy
2 / 2 / 1
Регистрация: 21.07.2015
Сообщений: 38
10.08.2015, 12:57 9
Ev[G]eN, немного не это хочу. Создал два метода: в первом вводим длину массива и элементы, вызываем метод, который прогонит введенный массив и создаст массив с индексами нулевых элементов. Вот как последний вывести на экран?.

LeanJava
Java
1
2
3
4
5
public class LeanJava {
    public static void main(String[] args) throws Exception {
        ZeroIndexesArr.createArr();
    }
}
ZeroIndexesArr
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
public class ZeroIndexesArr {
    
    public static void createArr() throws Exception{
        String answer = null;
        BufferedReader buffRead = new BufferedReader(new InputStreamReader(System.in));
        System.out.print("Введите длинну массива: ");
        int length = Integer.parseInt(buffRead.readLine());
        final int[] arr = new int[length];
        for (int count = 0; count < length; count++){
            System.out.print("Введите " + (count+1) + "-й элемент массива: ");
            arr[count] = Integer.parseInt(buffRead.readLine());
        }
        System.out.println(Arrays.toString(arr));
        getZeroIndexesArr(arr);
        
        
    }
    
    //метод возвращает массив, состоящий из индексов нулевых элементов arr[]
    public static int[] getZeroIndexesArr (int[] arr){
        if (arr.length==0)return null;
        int count = 0;
        for (int i = 0; i < arr.length; i++){
            if (arr[i]==0) count++;
        }
        final int[] zeroIndexesArr = new int[count];
        count = 0;
        for (int i = 0; i < arr.length; i++) {
            if ( arr[i]==0 ){
                zeroIndexesArr[count] = i+1;
                count++;
            }
        }
        return zeroIndexesArr; 
    }
}
0
ryadovoy
2 / 2 / 1
Регистрация: 21.07.2015
Сообщений: 38
12.08.2015, 11:33 10
Подскажите, можно ли правильнее/изящней/проще вывести массив номеров нулевых элементов? Главной задумкой было создать два метода: 1-й принимает массив с клавиатуры, 2-й на основе этого массива создает массив номеров нулевых элементов.
Java
1
2
3
4
5
6
7
public class LeanJava {
    public static void main(String[] args) throws Exception {
        ZeroIndexesArr z = new ZeroIndexesArr();
        System.out.println("Массив номеров нулевых элементов - " +
                Arrays.toString(z.getZeroIndexesArr(z.createArr())));
    }
}
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
public class ZeroIndexesArr {
    
    public static int[] createArr() throws Exception{
        BufferedReader buffRead = new BufferedReader(new InputStreamReader(System.in));
        System.out.print("Введите длинну массива: ");
        int length = Integer.parseInt(buffRead.readLine());
        final int[] arr = new int[length];
        for (int count = 0; count < length; count++){
            System.out.print("Введите " + (count+1) + "-й элемент массива: ");
            arr[count] = Integer.parseInt(buffRead.readLine());
        }
        return arr;
        
        
    }
    
    //метод возвращает массив, состоящий из индексов нулевых элементов arr[]
    public static int[] getZeroIndexesArr (int[] arr){
        if (arr.length==0)return null;
        int count = 0;
        for (int i = 0; i < arr.length; i++){
            if (arr[i]==0) count++;
        }
        final int[] zeroIndexesArr = new int[count];
        count = 0;
        for (int i = 0; i < arr.length; i++) {
            if ( arr[i]==0 ){
                zeroIndexesArr[count] = i+1;
                count++;
            }
        }
        return zeroIndexesArr; 
    }
}
0
12.08.2015, 11:33
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.08.2015, 11:33

Есть ли у матрицы столбцы состоящие из нулевых элементов
Дан массив В размерности n*m. Определить, есть ли у матрицы столбцы состоящие...

Найти количество и процентное соотношение положительных, отрицательных и нулевых элементов массива
Здравствуйте,помогите пожалуйста написать программа на Jave(( Дан...

Найти число положительных/нулевых элементов матрицы в строках, где первый элемент больше 1
Дана матрица, состоящая из n строк и n столбцов. Найти по отдельности число...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru