Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 24.02.2016
Сообщений: 32

Наведите на мысль решения задачи по массивам

25.03.2016, 15:39. Показов 618. Ответов 5

Студворк — интернет-сервис помощи студентам
Есть массив Objects. Задание - написать к нему различные методы (что нужно - под названием метода). Столкнулся с затруднением, как реализовать последних 2. Наведите на мысль, пожалуйста. (Если проверите правильность решения в целом, буду благодарен!)
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
public class ImprovedArray {
    private Objects[] objectsesArray = new Objects[10];
    private int count;
    String beautifullyDecoratedString = "";
    BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
 
    public void add(Objects value) {
        // добавляет элементы друг за другом
        if (count < objectsesArray.length) {
            objectsesArray[count] = value;
            count++;
        } else if (count == objectsesArray.length) {
            Objects[] tempStringArray = new Objects[count * 2];
            System.arraycopy(objectsesArray, 0, tempStringArray, 0, objectsesArray.length);
            objectsesArray = tempStringArray;
            objectsesArray[count] = value;
            count++;
        }
    }
 
    public Objects get(int index, Objects[] objectsesArray) {
        //возвращает элемент, находящийся по указанному индексу.
        return this.objectsesArray[index];
    }
 
    public int size() {
        // количество заполненных элементов (которые передали в метод add(String)) (не размер массива!)
        return count;
    }
 
    public boolean equals(ImprovedArray other) {
        // одинаковый размер
        // первый элемент одного равен первому элементу другого, второй - второму и т.д.
        if (this.size() != other.size()) {
            return false;
        } else {
            for (int i = 0; i < this.size(); i++) {
                if (this.objectsesArray[i].equals(other.objectsesArray[i])) {
                    continue;
                } else return false;
            }
        }
 
        return true;
    }
 
    public String toString() {
        //возвращает красиво оформленную строку (без null)
        for (int i = 0; i < count; i++) {
            beautifullyDecoratedString = beautifullyDecoratedString + objectsesArray[i] + " ";
        }
 
        return beautifullyDecoratedString;
    }
 
    public boolean contains(Object obj) {
        //проверки содержится ли элемент в массиве
        for (int i = 0; i < objectsesArray.length; i++) {
            if (objectsesArray[i].equals(obj)) {
                return true;
            } else {
                return false;
            }
        }
        return true;
    }
 
    public void remove(Objects index) {
        //удаления элемента по индексу (с перемещением последующих элементов)
               
    }
 
    public void remove(Object obj) {
        //удаления элемента (также с перемещением последующих)
 
    }
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.03.2016, 15:39
Ответы с готовыми решениями:

Наведите на мысль
Добрый день) Изучаю Borland C++ по А. Крейгу, надо ввести данную программу(приведена ниже), после компиляции выводит ошибки: ...

Счетчик количества товаров. Внедрение на сайт. Наведите на правильную мысль
Вот тестовый сайт моего интернет магазина http://1.tdprofnastil.ru/catalog/stroytovary/fanera/ Сделал счетчик товаров. Но при...

Наведите на решение задачи
Из пункта А в пункт В можно добраться: – по прямой; – по дуге окружности; – через пункт С, где участки от А до С и от С до В -...

5
1123 / 794 / 219
Регистрация: 15.08.2010
Сообщений: 2,185
25.03.2016, 15:49
для remove(Objects index) можно цикл от i=index+1 до count переписывать a[i-1]=a[i] и в конце a[--count] = null не забыть.
В удалении по объекту найти в цикле его индекс и вызвать remove по индексу
Быть может есть смысл укорачивать массив, если к примеру count < length/4
1
0 / 0 / 0
Регистрация: 24.02.2016
Сообщений: 32
25.03.2016, 16:21  [ТС]
У нас тип ожидаемых данных - objects, i=index+1 - не работает, пишет, что +1 не подходит для Objects (цикл for)
0
1123 / 794 / 219
Регистрация: 15.08.2010
Сообщений: 2,185
25.03.2016, 16:38
ATsurkanu, тогда в чем разница ремувов? И в комментарии написано удаление по индексу. Может все таки int передается?
И что за класс такой странный Objects?
1
0 / 0 / 0
Регистрация: 24.02.2016
Сообщений: 32
25.03.2016, 17:10  [ТС]
Да, Вы правы, я не доглядел!) Спасибо!
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
package HomeWork.HomeWork_22_03_16;
 
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.Objects;
 
/**
 * Created by Антон on 25.03.2016.
 */
public class ImprovedArray {
    private Object[] objectsesArray = new Objects[10];
    private int count;
    String beautifullyDecoratedString = "";
    BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
 
    public void add(Objects value) {
        // добавляет эелементы друг за другом
        if (count < objectsesArray.length) {
            objectsesArray[count] = value;
            count++;
        } else if (count == objectsesArray.length) {
            Objects[] tempStringArray = new Objects[count * 2];
            System.arraycopy(objectsesArray, 0, tempStringArray, 0, objectsesArray.length);
            objectsesArray = tempStringArray;
            objectsesArray[count] = value;
            count++;
        }
    }
 
    public Objects get(int index, Objects[] objectsesArray) {
        //возвращает элемент, находящийся по указанному индексу.
        return objectsesArray[index];
    }
 
    public int size() {
        // количество заполненных элементов (которые передали в метод add(String)) (не размер массива!)
        return count;
    }
 
    public boolean equals(ImprovedArray other) {
        // одинаковый размер
        // первый элемент одного равен первому элементу другого, второй - второму и т.д.
        if (this.size() != other.size()) {
            return false;
        } else {
            for (int i = 0; i < this.size(); i++) {
                if (this.objectsesArray[i].equals(other.objectsesArray[i])) {
                    continue;
                } else return false;
            }
        }
 
        return true;
    }
 
    public String toString() {
        //возвращает красиво оформленную строку (без null)
        for (int i = 0; i < count; i++) {
            beautifullyDecoratedString = beautifullyDecoratedString + objectsesArray[i] + " ";
        }
 
        return beautifullyDecoratedString;
    }
 
    public boolean contains(Object obj) {
        //проверки содержится ли элемент в массиве
        for (int i = 0; i < objectsesArray.length; i++) {
            if (objectsesArray[i].equals(obj)) {
                return true;
            } else {
                return false;
            }
        }
        return true;
    }
 
    public void remove(int index) {
        /*удаления элемента по индексу (с перемещением последующих элементов) для remove(Objects index)
         можно цикл от i=index+1 до count переписывать a[i-1]=a[i] и в конце a[--count] = null не забыть.
        В удалении по объекту найти в цикле его индекс и вызвать remove по индексу*/
 
    }
 
    public void remove(Object obj) {
        //удаления элемента (также с перемещением последующих)
 
    }
}
Добавлено через 25 минут
Не хочу показаться совсем глупым, но не понимаю, как реализовать второй метод. Первый, вроде бы, реализовал.
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public void remove(int index) {
        //удаления элемента по индексу (с перемещением последующих элементов)
 
        for (int i = index + 1; i < count; i++) {
            objectsesArray[i-1] = objectsesArray[i];
            objectsesArray[--count] = null;
        }
    }
 
    public void remove(Object obj) {
        //удаления элемента (также с перемещением последующих)
        //В удалении по объекту найти в цикле его индекс и вызвать remove по индексу
        
    }
0
1123 / 794 / 219
Регистрация: 15.08.2010
Сообщений: 2,185
25.03.2016, 17:40
Цитата Сообщение от ATsurkanu Посмотреть сообщение
objectsesArray[--count] = null;
это вне цикла!
Про второе:
Java
1
2
for(...)
if a[i].equals(obj) {remove(i); break;}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.03.2016, 17:40
Помогаю со студенческими работами здесь

задачи по массивам
Доброго времени суток! Помогите с решением. Нужно использовать массивы. {a}_{1}, {a}_{2}, ... действительные числа {a}_{1}&gt;0 и...

Задачи по массивам
заранее спасибо!!

Задачи по массивам
короч котаны есть проблема плохо разбираюсь в массивах, помогите кто чем смоЖет а?)) 2 задачи 1.Определить средний рост девочек, и...

Задачи по массивам
Здравствуйте! Помогите пожалуйста сделать задачки по JavaScript, с использованием класса array. 1) Нaйти сумму элeмeнтов мaссивa...

2-е задачи по массивам
Здравствуйте, помогите решить две задачи по паскалю, заранее огромное спасибо! 1. Массив из чисел 0-50. Найдите сумму номеров и сумму...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru