Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
 Аватар для videolord
49 / 15 / 2
Регистрация: 20.02.2011
Сообщений: 152

Создать вектор с возможностью отрицательной индексации

31.03.2011, 18:15. Показов 2488. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как можно создать массив на java с определенным интервалом
например b:array[-500000..500000]of boolean;
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
31.03.2011, 18:15
Ответы с готовыми решениями:

Шаблон класса вектор с операциями индексации и функциями insert и erase
У меня есть задача. функции erase и insert я реализовала. но чтобы они работали нужно написать LOL& operator(int); Задача звучит...

Класс "вектор" с конструкторами, позволяющими создать нулевой вектор и вектор с произвольным числом элементов
Привет! Задача следующая. Нужно реализовать класс "вектор" с конструкторами, которые позволяют создать нулевой вектор и вектор с...

Создать иерархию классов вектор и безопасный вектор с проверкой выхода за пределы
Создать иерархию классов вектор и безопасный вектор с проверкой выхода за пределы. Безопасный вектор определяет переменные нижний и верхний...

14
Эксперт JavaЭксперт С++
 Аватар для M128K145
8384 / 3617 / 419
Регистрация: 03.07.2009
Сообщений: 10,709
31.03.2011, 18:26
videolord, нет, ну я не знаю на каком языке вы привели пример, но такой интервал для булеана, которому по сути 1 бита с головой хватит...
Вы можете только при заполнении самостоятельно валидировать вносимые данные, других вариантов я не знаю
1
 Аватар для videolord
49 / 15 / 2
Регистрация: 20.02.2011
Сообщений: 152
31.03.2011, 18:49  [ТС]
язык Pascal

Добавлено через 13 минут
а если так я хочу сделать
чтобы мог ввести в X и отрицательные числа

должен быть не так boolean[] Mas=new boolean[500000];
а от -500000 до 500000

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
import java.util.Arrays;
import java.util.Scanner;
public class problem1021 {
public static void main(String[] args) {
 Scanner sc=new Scanner(System.in);
  boolean[] Mas=new  boolean[500000];
  Arrays.fill(Mas, false);
    int n=sc.nextInt();
    for (int i=0;i<n;i++){
    int x=sc.nextInt();
    Mas[x]=true;
 }}
}


Добавлено через 21 секунду
а на С++ так делается,а на яве

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
using namespace std;
 
template<size_t start, size_t end, class T>
class PascalArray
{
   T arr[end-start+1];
public:
   inline T& operator[](size_t index)
   {
       return arr[index-start];
   }
};
 
int main()
{
   PascalArray<-10, 10, int> arr;
   for(int i = -10; i<=10; i++) arr[i] = i;
   for(int i = -10; i<=10; i++) cout << arr[i] << endl;
   return 0;
}
0
Эксперт JavaЭксперт С++
 Аватар для M128K145
8384 / 3617 / 419
Регистрация: 03.07.2009
Сообщений: 10,709
31.03.2011, 18:49
videolord, вы сейчас о размерности массива говорите в таком интервале? или я вас совсем не пойму?

Все, я вас понял. Я правда не знаю зачем вам такой финт ушами с такой индексацией, но посоветую вам написать свой вариант списка, можно построить его даже на массиве
1
 Аватар для videolord
49 / 15 / 2
Регистрация: 20.02.2011
Сообщений: 152
31.03.2011, 18:52  [ТС]
да! о размерности !

Добавлено через 1 минуту
чтоб индексы массива были отрицательными
0
Эксперт JavaЭксперт С++
 Аватар для M128K145
8384 / 3617 / 419
Регистрация: 03.07.2009
Сообщений: 10,709
31.03.2011, 18:55
videolord, ответ выше, собственно на С++ написан аналог вектора, вы можете сделать такой же аналог и на Java, только индексация будет в стиле Java - .get(int index), а не С++ - [int index]
1
 Аватар для videolord
49 / 15 / 2
Регистрация: 20.02.2011
Сообщений: 152
31.03.2011, 18:59  [ТС]
я не знаю как работать с векторами,можете превести на java,очень прошу
0
Эксперт JavaЭксперт С++
 Аватар для M128K145
8384 / 3617 / 419
Регистрация: 03.07.2009
Сообщений: 10,709
31.03.2011, 20:34
Вот вам самый примитивный вариант:
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
class Array<Type> {
   private Type[] array;
   int start, end;
 
   public Array(int start, int end) {
      this.array = (Type[]) new Object[end - start];
      this.start = start;
      this.end = end;
   }
 
   public void set(int index, Type value) {
      array[index - start] = value;
   }
 
   public Type get(int index) {
      return array[index - start];
   }
}
 
class Main {
 
   public static void main(String[] args) {
      Array<Integer> arr = new Array<Integer>(-10, 10);
      int i;
      for (i = -10; i < 10; ++i)
         arr.set(i, i);
      for (i = -10; i < 10; ++i)
         System.out.print(i + " ");
   }
}
Добавлено через 2 минуты
Цитата Сообщение от videolord Посмотреть сообщение
C++
1
T arr[end-start+1];
Эта строка не соответствует C-based языкам и является моветоном
2
 Аватар для videolord
49 / 15 / 2
Регистрация: 20.02.2011
Сообщений: 152
31.03.2011, 20:39  [ТС]
Огромнейшее спасибо тебе M128K145!!!
0
01.04.2011, 07:39

Не по теме:

Вместо массивов boolean лучше использовать java.util.BitSet

0
 Аватар для videolord
49 / 15 / 2
Регистрация: 20.02.2011
Сообщений: 152
02.04.2011, 09:41  [ТС]
aleksandy я не совсем вас понял!Вы што имелу в виду?Пожалуйста на примере можете обьяснить
0
Эксперт С++
 Аватар для CyBOSSeR
2348 / 1721 / 149
Регистрация: 06.03.2009
Сообщений: 3,675
02.04.2011, 09:50
Цитата Сообщение от videolord Посмотреть сообщение
Вы што имелу в виду?
Что для хранения последовательности булевских значений вместо массива лучше использовать специализированный класс BitSet.
Модифицированный код M128K145:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
class FancyBooleanVector {
   private final BitSet bits;
   private final int start;
 
   public FancyBooleanVector(int start, int end) {
      this.bits = new BitSet(end - start);
      this.start = start;
   }
 
   public void set(int index, boolean value) {
      bits.set(index - start, value);
   }
 
   public boolean get(int index) {
      return bits.get(index - start);
   }
}
1
 Аватар для videolord
49 / 15 / 2
Регистрация: 20.02.2011
Сообщений: 152
02.04.2011, 10:01  [ТС]
просто мне надо было заполнить этот массив falsom
но не получается,Arrays.fill(Arr,false) тута не работает,а как можно заполнить этот массив falsom
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
class Array<Type> {
   private Type[] array;
   int start, end;
 
   public Array(int start, int end) {
      this.array = (Type[]) new Object[end - start];
      this.start = start;
      this.end = end;
   }
 
   public void set(int index, Type value) {
      array[index - start] = value;
   }
 
   public Type get(int index) {
      return array[index - start];
   }
}
 
class Main {
 
   public static void main(String[] args) {
      Array<Boolean> arr = new Array<Boolean>(-10, 10);
Arrays.fill(Arr,false);
}
}
Добавлено через 41 секунду
или с помошью bitset
0
Эксперт С++
 Аватар для CyBOSSeR
2348 / 1721 / 149
Регистрация: 06.03.2009
Сообщений: 3,675
02.04.2011, 10:17
videolord, из документации по BitSet:
By default, all bits in the set initially have the value false.
Учитесь работать с документацией.

Если я правильно понял документацию по проверке утверждений в Java, то так кошерней будет:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
class FancyBooleanVector {
   private final BitSet bits;
   private final int start;
 
   public FancyBooleanVector(int start, int end) {
      assert start < 0 && end > 0;
      
      this.bits = new BitSet(end - start);
      this.start = start;
   }
 
   public void set(int index, boolean value) {
      bits.set(index - start, value);
   }
 
   public boolean get(int index) {
      return bits.get(index - start);
   }
}
0
636 / 528 / 165
Регистрация: 01.04.2010
Сообщений: 1,843
03.04.2011, 09:03
Цитата Сообщение от CyBOSSeR Посмотреть сообщение
Java
1
assert start < 0 && end > 0;
Эта строка ничего не даст, если JVM не будет запущена с соответствующим ключом.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.04.2011, 09:03
Помогаю со студенческими работами здесь

Создать иерархию классов вектор и безопасный вектор с проверкой выхода за пределы
Создать иерархию классов вектор и безопасный вектор с проверкой выхода за пределы. Безопасный вектор определяет переменные нижний и верхний...

Создать иерархию классов вектор(longint) и безопасный вектор с проверкой выхода за пределы
Помогите не знаю как сделать! Создать иерархию классов вектор(longint) и безопасный вектор с проверкой выхода за пределы. Безопасный...

Матрица и вектор. Создать вектор, содержащий количество отрицательных элементов каждого столбца
Создать вектор М, т.е. одно мерный массив, содержащий количество отрицательных элементов каждого столбца матрицы z(3,4).

Дан целочисленный вектор А(12), среди его элементов есть одинаковые. Создать вектор В из различных элементов вектора А
Дан целочисленный вектор А(12), среди его элементов есть одинаковые. Создать вектор В из различных элементов вектора А.

Создать класс, полями есть динамический вектор(то есть указатель на вектор) его размер и идентификатор
Задание нужно создать класс, полями есть динамический вектор(то есть указатель на вектор) его размер та идентификатор не получается в...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru