|
Временно недоступен
957 / 228 / 14
Регистрация: 12.04.2009
Сообщений: 926
|
|||||||||||
Можно ли выразить порядковый номер элемента массива через индексы?13.09.2009, 06:02. Показов 9592. Ответов 11
Метки нет (Все метки)
Допустим,есть двумерный массив a[5][6], и необходимо получить доступ к элементу a[3][4];можно ли как-то узнать его порядковый номер в массиве,полагая,что если бы массив был разложен в линейное множество,его строки следовали бы одна за другой,а элементы нумеровались как в обычном линейном множестве,начиная с нуля(или 1)и до количества элементов?
Например:
Какая-то формула?
0
|
|||||||||||
| 13.09.2009, 06:02 | |
|
Ответы с готовыми решениями:
11
Вывести порядковый номер элемента массива
|
|
быдлокодер
1724 / 911 / 106
Регистрация: 04.06.2008
Сообщений: 5,705
|
|
| 13.09.2009, 06:30 | |
|
Дан двумерный массив mass [i, j] и элемент массива el (I, J)
В линейном аналоге массива mass элемент el будет иметь номер I*j+ J Это что ли?
1
|
|
|
2924 / 1274 / 114
Регистрация: 27.05.2008
Сообщений: 3,465
|
||
| 13.09.2009, 13:17 | ||
|
1
|
||
|
562 / 373 / 55
Регистрация: 05.04.2009
Сообщений: 767
|
|||||||
| 13.09.2009, 13:43 | |||||||
|
так
1
|
|||||||
|
|
|
| 13.09.2009, 13:46 | |
|
Скажем так, в Си нет многомерных массивов как таковых. Есть только массив массивов. kravam написал, как туда устраивать доступ
В общем случае будет примерно так: если есть массив "int arr[A][B][C][D]", то доступ к элементу "arr[a][b][c][d]" осуществляется (по стандарту языка) по адресу "((int*)&arr[0][0][0][0]) + a*(B*C*D) + b*(C*D) + c *(D) + d"
1
|
|
|
Временно недоступен
957 / 228 / 14
Регистрация: 12.04.2009
Сообщений: 926
|
||||||||||||||||
| 13.09.2009, 14:29 [ТС] | ||||||||||||||||
|
То есть если массив семимерный,
Не по теме: Evg вернуля уже? :)
0
|
||||||||||||||||
|
8384 / 3617 / 419
Регистрация: 03.07.2009
Сообщений: 10,709
|
|
| 13.09.2009, 14:41 | |
|
скорее так
2*(2*5*3*6*9*1) + 1*(5*3*6*9*1) + 4*(3*6*9*1) + 2*(6*9*1) + 4*(9*1) + 6*1 + 0
1
|
|
|
|
|
| 13.09.2009, 15:02 | |
|
#pragma, ты напутал. Полагаю, что номера размерностей и индексов считаются от 1. При построении выражения 1-ый индекс надо помножить на размерности от 2 до 7, 2-й индекс помножать на размерности от 3 до 7 и т.д. Т.е. каждый индекс умножается на все "более поздние" размерности
1
|
|
|
Отдыхающий:)
94 / 91 / 22
Регистрация: 05.04.2009
Сообщений: 188
|
|
| 13.09.2009, 15:05 | |
|
Поправьте если я ошибаюсь, но:
К Статически созданному масиву на С++, можно обратиться так: int a[10][5]; a[0][4] = a[4]//4-ый элемент 12-элемент = a[2][1] - двумерном представлении и a[11] в одномерном. Происходит это из-за того что в статически созданном масиве элементы располагаются по порядку. *(a+11) = a[11] = 12-ый элемент Если нужно больше информации почитайте книгу Герберта Шилдта "С++ для начинающих"
1
|
|
|
Временно недоступен
957 / 228 / 14
Регистрация: 12.04.2009
Сообщений: 926
|
|||
| 13.09.2009, 15:11 [ТС] | |||
Не советуют данное чтиво в авторитетных кругах.Добавлено через 1 минуту
0
|
|||
|
|
|
| 13.09.2009, 15:37 | |
|
Тогда ты на верном пути
1
|
|
| 13.09.2009, 15:37 | |
|
Помогаю со студенческими работами здесь
12
Вывести порядковый номер элемента массива C++ Builder Определить порядковый номер 1-го положительного элемента массива А
Как вывести порядковый номер элемента массива Можно ли как-то получить порядковый номер элемента из этого списка (тот, который выбираешь)? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Символьное дифференцирование
igorrr37 13.02.2026
/ *
Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2).
Унарный минус обозначается как !
*/
#include <iostream>
#include <stack>
#include <cctype>. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога
Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
|
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
|