Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Удаление элемента массива 
:(
    Опции темы
00100
Дата 17.10.2008, 19:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 30.3.2008

Репутация: нет
Всего: нет



Здравствуйте! Есть массив double[][] masA = new double[2][5]; Вопрос заключается в том что когда я сравниваю элементы массива то мне необходимо удалять строки массива (или элемент), но как это сделать я не пойму если я присваиваю элементу null, то пишет что ошибка.
PM MAIL   Вверх
mbasil
Дата 17.10.2008, 20:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 399
Регистрация: 4.5.2007
Где: Москва

Репутация: 2
Всего: 13



Вы не можете присвоить примитивной переменной (а элемент вашего массива это примитив) null значение.
В таком случае надо либо присвоить какое-либо незначащее значение с точки зрения приложения значение.  Но если вам задачу поставил преподаватель, он скорее всего имел в виду, что вы при удалении сдвините весь хвост массива для того, чтобы этот элемент просто исчез.
PM MAIL   Вверх
00100
Дата 17.10.2008, 20:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 30.3.2008

Репутация: нет
Всего: нет



Цитата(mbasil @ 17.10.2008,  20:06)
Вы не можете присвоить примитивной переменной (а элемент вашего массива это примитив) null значение.
В таком случае надо либо присвоить какое-либо незначащее значение с точки зрения приложения значение.  Но если вам задачу поставил преподаватель, он скорее всего имел в виду, что вы при удалении сдвините весь хвост массива для того, чтобы этот элемент просто исчез.

Да нет преподаватель здесь не причем smile собственная инициатива, просто у меня элементы массива сравниваются, а потом мне нужно то что уже прошло сравнение удалить, а незначащее число я поставить не могу т.к. он тогда опять будет с этим элементом сравнивать...


Это сообщение отредактировал(а) 00100 - 17.10.2008, 20:14
PM MAIL   Вверх
mbasil
Дата 17.10.2008, 20:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 399
Регистрация: 4.5.2007
Где: Москва

Репутация: 2
Всего: 13



Значит надо сдвигать хвост массива.
Может в этой ситуации лучше использовать коллекции, например Set, не вставляет дубликаты.
PM MAIL   Вверх
00100
Дата 17.10.2008, 21:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 30.3.2008

Репутация: нет
Всего: нет



Цитата(mbasil @ 17.10.2008,  20:24)
Значит надо сдвигать хвост массива.
Может в этой ситуации лучше использовать коллекции, например Set, не вставляет дубликаты.

вот смотрите 
Код

for (int i = 2; i <= n; i++)
        {
            ff[i - 1] = ff[i];
        }

из массива допустим я удалил 2 элемент но как мне теперь его длину уменьшить?

PM MAIL   Вверх
duk
Дата 17.10.2008, 22:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Some Object
*


Профиль
Группа: Участник
Сообщений: 179
Регистрация: 19.7.2007

Репутация: 4
Всего: 4



Посмотри ArrayList, там есть все эти штуки
PM MAIL   Вверх
biguser
Дата 17.10.2008, 23:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 7
Регистрация: 29.8.2007

Репутация: нет
Всего: нет



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

если надо сделать всё таки такую возможность нужно использовать уже List->ArrayList и т.д.

Это сообщение отредактировал(а) biguser - 17.10.2008, 23:24
PM MAIL   Вверх
Keyo
Дата 18.10.2008, 03:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 95
Регистрация: 10.4.2008

Репутация: нет
Всего: нет



наверное лучше связанный список LinkedList
PM MAIL   Вверх
Dims
Дата 18.10.2008, 13:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1016
Регистрация: 21.11.2006

Репутация: 4
Всего: 11



Чё-то я не понял. Одномногомерный массив -- это массив массивов. На самом последнем уровне у нас конечный тип, если он не ссылочный, то ему, конечно, null присвоить нельзя. Ну а не на конечном уровне тип ссылочный -- массив меньшей размерности. Ему вполне можно присвоить null.

Вот такой код 

Код

        double[][] masA = new double[2][5];

        for (int i = 0; i < masA.length; ++i) {
            for (int j = 0; j < masA[i].length; ++j) {
                masA[i][j] = i + j;
            }
        }

        masA[1] = null;

        for (int i = 0; i < masA.length; ++i) {
            System.out.print(String.valueOf(i) + ": ");
            if (masA[i] != null) {
                for (int j = 0; j < masA[i].length; ++j) {
                    if (j > 0) {
                        System.out.print(",");
                    }
                    System.out.print(j);
                }
            }
            else {
                System.out.print("null");
            }
            System.out.println("");
        }



выдаёт вот это

0: 0,1,2,3,4
1: null

То есть, строка совершенно нормально удалилась.

Отсюда напрашивается решение (если есть желание убивать строки и элементы присваиванием null) -- добавить ещё одну размерность длины 1.

double[][][] masA = new double[2][5][1];

чтобы обратиться 

к элементу 1-0 надо будет писать

masA[1][0][0]

то есть, всегда добавлять в конце [0].

Это сообщение отредактировал(а) Dims - 18.10.2008, 13:16
PM MAIL   Вверх
Temdegon
Дата 18.10.2008, 16:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 429
Регистрация: 11.10.2008
Где: Minsk

Репутация: 7
Всего: 9



А почему нельзя просто использовать классы-обертки для примитивных типов? Испоьзуй Integer вместо int. Тем более начиная с  5-й Java работать с ними удобно блягодаря autoBoxing.

Это сообщение отредактировал(а) Temdegon - 18.10.2008, 16:15
PM MAIL   Вверх
dorogoyIV
Дата 18.10.2008, 16:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1503
Регистрация: 26.3.2007

Репутация: 3
Всего: 46



кажется все забыли про:
Код

 System.arraycopy(...);

 smile 
PM MAIL   Вверх
00100
Дата 19.10.2008, 01:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 30.3.2008

Репутация: нет
Всего: нет



dorogoyIV, Temdegon, Dims, Keyo, biguser, duk Спасибо Вам всем огромное! Реализовал я через спски и просто удалением и смещением массива все понял, вопрос закрыт...
p.s. новые вопросы обязательно будут  smile 
PM MAIL   Вверх
Исполнитель234
Дата 15.12.2009, 12:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 135
Регистрация: 3.7.2008
Где: Украина

Репутация: нет
Всего: 1



Помогите найти идеальную реализацию.

Задачка такова: нужно удалить все потонувшие лодки
Код


final int MAX_CELLS = 500;

Vector sea = new Vector(MAX_CELLS);


addBoat()
{
    for(int i=0; i<MAX_CELLS; i++) sea.add(new Boat(i+1));
}

removeBulBulboat()
{
    for(int i=0; i<MAX_CELLS; i++)
    {
        if(boat.Bul_bul()) sea.remove(boat);
    }

}


Можно ли так удалять элементы? Или можно оптимизировать как-то?

В интернете гуглил, нашел что в векторе элементы перенумеровываются сразу после удаления

Стало быть вектор использовать нельзя, нужен линкед лист? 

--------------------
Тестирую UI, консультирую по вопросам юзабилити, проектирую, составляю грамотные ТЗ.
PM MAIL WWW ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0708 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.