Форум программистов, компьютерный форум CyberForum.ru

в ОЗУ массив a[i][j] - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.89
xTIGRx
 Аватар для xTIGRx
292 / 198 / 2
Регистрация: 23.10.2010
Сообщений: 1,169
Записей в блоге: 1
24.08.2011, 11:00     в ОЗУ массив a[i][j] #1
есть такой код
C++
1
2
3
4
5
6
7
8
9
10
11
for(int i=0;i<40;i++)
{
    for(int j=0;j<40;j++)
    {
        switch(a[i][j])
        {
            case 1: b->Canvas->Brush->Color=clBlack; break;
            case 0: b->Canvas->Brush->Color=clGreen; break;
            case 2: b->Canvas->Brush->Color=clGray; break;
            case 3: b->Canvas->Brush->Color=clYellow; break;
        }
как можно записать в ОЗУ массив a[i][j], чтобы каждый раз не использовать функцию for???

Добавлено через 4 минуты
Тоетсь как можно обратиться ко всему массиву 'a', без индекса ячейки
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
24.08.2011, 11:09     в ОЗУ массив a[i][j] #2
GoldDragon, не понятно, чего вы хотите? Что значит "записать массив в ОЗУ"? Он и так находится в памяти. Что значит "обратиться ко всему массиву, без индекса ячейки"? Чего вы хотите добиться?
xTIGRx
 Аватар для xTIGRx
292 / 198 / 2
Регистрация: 23.10.2010
Сообщений: 1,169
Записей в блоге: 1
24.08.2011, 11:59  [ТС]     в ОЗУ массив a[i][j] #3
Ну да без индекса, тоесть обратиться ко всему массиву, если просто ввести букву a без кавычек [][], то ничего работать не будет, короче сделать ГЛОБАЛЬНЫЙ поиск в массиве a
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
24.08.2011, 12:12     в ОЗУ массив a[i][j] #4
GoldDragon, и снова я не понял, чего вы хотите? Что значит "глобальный поиск"? Как вы собираетесь обратиться ко "всему массиву"? Приведите пример того, чего вы хотите.
xTIGRx
 Аватар для xTIGRx
292 / 198 / 2
Регистрация: 23.10.2010
Сообщений: 1,169
Записей в блоге: 1
24.08.2011, 12:22  [ТС]     в ОЗУ массив a[i][j] #5
Цитата Сообщение от silent_1991 Посмотреть сообщение
Как вы собираетесь обратиться ко "всему массиву"?
поэтому я и спрашиваю это возможно или нет, вот когда пишите a[5], это значит в массиве a есть 5 ячеек и в каждой ячейке хранится какое то значение, так вот как сделать так чтобы не искать в каждой ячейке вот так
C++
1
2
3
4
5
for(int i=0;i<5;i++)
{
     a[i];
     ShowMessage(a[i]);
}
А сразу ShowMessage(a);, тоесть всё что есть в массиве то и должно выводится, может код который я написал не будет работать потому что эт я щас на ходу написал, это пример для вас, ну так как вы знаете возможно ли такое в C++????
Евгений М.
1033 / 974 / 53
Регистрация: 28.02.2010
Сообщений: 2,817
Завершенные тесты: 2
24.08.2011, 12:33     в ОЗУ массив a[i][j] #6
Цитата Сообщение от GoldDragon Посмотреть сообщение
вот когда пишите a[5], это значит в массиве a есть 5 ячеек
Не пишем, а объявляем. Внимательнее.

Цитата Сообщение от GoldDragon Посмотреть сообщение
тоесть всё что есть в массиве то и должно выводится
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <iostream>
#include <sstream>
#include <string>
using namespace std;
 
int main () {
 
  stringstream oss;
  int a[5];
 
  // ...
 
  for (int i=0; i<5; i++)
  {
    oss << a[i] << " ";
  }
  mystr=oss.str();
 
  cout << mystr << endl;  // выведет все элементы массива через пробел
 
  return 0;
}
Для этого нужно знать как работать с stringstream и string. Есть и другие способы.
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
24.08.2011, 12:47     в ОЗУ массив a[i][j] #7
GoldDragon, я так понял, вам не хочется писать цикл (чего бы то ни было: поиска, вывода на экран и т.д.), а сразу получить результат. Если так, то надо воспользоваться алгоритмами стандартной библиотеки. Хотя, по сути, это будут те же самые циклы, просто запрятанные в стандартные функции.
Например, алгоритм std::find поможет найти в контейнере нужный элемент, а с помощью алгоритма std::copy и итераторов выходного потока контейнер можно вывести на экран.
xTIGRx
 Аватар для xTIGRx
292 / 198 / 2
Регистрация: 23.10.2010
Сообщений: 1,169
Записей в блоге: 1
24.08.2011, 13:11  [ТС]     в ОЗУ массив a[i][j] #8
silent_1991
просто для создания игры мне нужно как то в ОЗУ сохранить этот массив и не делать каждый раз поиск в массиве посимвольно, (имею ввиду через for) а про std::find у вас есть книга, ну или откуда вы узнали про std::?
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
24.08.2011, 13:20     в ОЗУ массив a[i][j] #9
GoldDragon, скажите, как вы соотносите хранение массива в ОЗУ (который и так в ОЗУ) и поиск по нему? Если массив однажды изменится, то результат предыдущего поиска всё равно может стать недействительным, находись массив в ОЗУ, в файле или в сети на сервере.
На счёт find и других алгоритмов, а так же контейнеров можно прочитать у Джосаттиса в книге по STL.
TheAthlete
 Аватар для TheAthlete
151 / 151 / 12
Регистрация: 31.08.2010
Сообщений: 529
25.08.2011, 10:30     в ОЗУ массив a[i][j] #10
Цитата Сообщение от GoldDragon Посмотреть сообщение
как можно записать в ОЗУ массив a[i][j], чтобы каждый раз не использовать функцию for???
никак, т.к. тебе нужно найти числа (в данном случае числа 0, 1, 2, 3), и ты должен проверять каждый элемент массива с данными числами.

как вариант могу предложить развернуть двумерный массив в одномерный, отсортировать его и использовать бинарный поиск.

Цитата Сообщение от GoldDragon Посмотреть сообщение
функцию for
for - это не функция, а оператор цикла
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.08.2011, 12:12     в ОЗУ массив a[i][j]
Еще ссылки по теме:

Описать структуру ОЗУ C++
C++ Порядок хранения структур в ОЗУ и memset
C++ Модифицируйте эмулятор с целью моделирования случайных сбоев ОЗУ

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

Или воспользуйтесь поиском по форуму:
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
25.08.2011, 12:12     в ОЗУ массив a[i][j] #11
Цитата Сообщение от TheAthlete Посмотреть сообщение
как вариант могу предложить развернуть двумерный массив в одномерный, отсортировать его и использовать бинарный поиск
Можно и не разворачивая отсортировать. Другое дело, что раз данные хранятся в матрице, то упорядоченным вектором они быть не должны.)
Yandex
Объявления
25.08.2011, 12:12     в ОЗУ массив a[i][j]
Ответ Создать тему
Опции темы

Текущее время: 01:37. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru