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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 18, средняя оценка - 4.83
nill
9 / 9 / 0
Регистрация: 16.08.2009
Сообщений: 417
#1

Побитовый сдвиг массива - C++

23.03.2010, 23:13. Просмотров 2336. Ответов 4
Метки нет (Все метки)

Есть двумерный массив
C++
1
int massiv[10][2];
Нужно сдвинуть первый элемент массива в конец, а все остальные соответственно вперед.
В цикле это можно сделать так

C++
1
2
3
4
5
6
7
int temp0=0; int temp1=0; int n=0;
 
for(int i=1; i<10; i++){
temp0= massiv[i][0]; temp1= massiv[i][1];
massiv[i][0]=massiv[n][0]; massiv[i][1]=massiv[n][1];
massiv[n][0]=temp0;  massiv[n][1]=temp1;  n++;
}
Но это очень медленный способ, как сделать то же самое используя побитовый сдвиг массива, интересует самый быстрый вариант.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.03.2010, 23:13     Побитовый сдвиг массива
Посмотрите здесь:

Побитовый сдвиг C++
C++ Побитовый сдвиг
Побитовый сдвиг C++
Реализовать функцию, которая осуществляет циклический побитовый сдвиг вправо на n позиций C++
Не могу понять, как работает побитовый сдвиг C++
Побитовый сдвиг C++
Как происходит побитовый сдвиг? C++
Побитовый сдвиг C++
C++ Побитовый сдвиг влево и вправо
Побитовый сдвиг C++
Как реализовать правильный побитовый сдвиг? C++
Получить введенное значение используя операции сложения, вычитания и побитовый сдвиг влево C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Зоти Сергей
228 / 226 / 13
Регистрация: 18.12.2009
Сообщений: 316
24.03.2010, 00:31     Побитовый сдвиг массива #2
так может попробовать:

C++
1
2
3
4
5
6
#define SIZEM 10
#define SIZEN 2
...
int c=massiv[0][0];
memcpy(&massiv[0][0],&massiv[0][1],sizeof(massiv)-sizeof(int));
massiv[SIZEM-1][SIZEN-1]=c;
nill
9 / 9 / 0
Регистрация: 16.08.2009
Сообщений: 417
24.03.2010, 01:08  [ТС]     Побитовый сдвиг массива #3
спасибо за пример
но код не работает

к примеру исходный массив такой
massiv[0][0] 34 massiv[0][1] 19
massiv[1][0] 5 massiv[1][1] 2
massiv[2][0] 8 massiv[2][1] 8
massiv[3][0] 0 massiv[3][1] 0
massiv[4][0] 0 massiv[4][1] 0
massiv[5][0] 0 massiv[5][1] 0
massiv[6][0] 0 massiv[6][1] 0
massiv[7][0] 0 massiv[7][1] 0
massiv[8][0] 0 massiv[8][1] 0
massiv[9][0] 0 massiv[9][1] 0

твой код выдает это
massiv[0][0] 19 massiv[0][1] 5
massiv[1][0] 2 massiv[1][1] 8
massiv[2][0] 8 massiv[2][1] 0
massiv[3][0] 0 massiv[3][1] 0
massiv[4][0] 0 massiv[4][1] 0
massiv[5][0] 0 massiv[5][1] 0
massiv[6][0] 0 massiv[6][1] 0
massiv[7][0] 0 massiv[7][1] 0
massiv[8][0] 0 massiv[8][1] 0
massiv[9][0] 0 massiv[9][1] 34

а должно быть
massiv[0][0] 5 massiv[0][1] 2
massiv[1][0] 8 massiv[1][1] 8
massiv[2][0] 0 massiv[2][1] 0
massiv[3][0] 0 massiv[3][1] 0
massiv[4][0] 0 massiv[4][1] 0
massiv[5][0] 0 massiv[5][1] 0
massiv[6][0] 0 massiv[6][1] 0
massiv[7][0] 0 massiv[7][1] 0
massiv[8][0] 0 massiv[8][1] 0
massiv[9][0] 34 massiv[9][1] 19
Зоти Сергей
228 / 226 / 13
Регистрация: 18.12.2009
Сообщений: 316
24.03.2010, 01:59     Побитовый сдвиг массива #4
Код работает если по порядку к эл. обращаться. В исходном массиве 2-ой эллемент равен 19 а не 5
C++
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
        massiv[0][0] =34;           //первый эл. 
        massiv[0][1] =19;           // второй эл.
 
    massiv[1][0] =5;
        massiv[1][1] =2;
 
    massiv[2][0] =8;
        massiv[2][1] =8;
 
    massiv[3][0] =0;
        massiv[3][1] =0;
 
    massiv[4][0] =0;
        massiv[4][1] =0;
 
    massiv[5][0] =0;
        massiv[5][1] =0;
 
    massiv[6][0] =0;
        massiv[6][1] =0;
 
    massiv[7][0] =0;
        massiv[7][1] =0;
 
    massiv[8][0] =0;
        massiv[8][1] =0;
 
    massiv[9][0] =0;
        massiv[9][1] =0;[/B]
Добавлено через 9 минут
При заполнении массива если используйте вложенный цикл, поменяте местами строки и столбцы, например:
C++
1
2
3
4
5
6
7
8
9
10
11
12
#define SIZEM 10
#define SIZEN 2
int b=0;
Упорядоченный в памяти массив
for(int i=0;i<SIZEM;i++)
            for(int j=0;j<SIZEN;j++)
                    massiv[i][j]=b++;
 
не упорядоченный в памяти массив:
        for(int j=0;j<SIZEN;j++)
            for(int i=0;i<SIZEM;i++)
                    massiv[i][j]=b++;
Добавлено через 11 минут
Проверить последовательность можете так:

C++
1
2
3
int *P=&massiv[0][0];
for(int i=0;i<SIZEM*SIZEN;i++)
        printf("%d\n",P[i]);
nill
9 / 9 / 0
Регистрация: 16.08.2009
Сообщений: 417
24.03.2010, 05:51  [ТС]     Побитовый сдвиг массива #5
Добавлено через 3 часа 5 минут
вобщем я разобрался как это записать

C++
1
memcpy(&massiv[0][0],&massiv[1][0],20*4-8);
но разве это и есть побитовый сдвиг массива ?
мне важно чтобы этот способ был самым быстрым
Yandex
Объявления
24.03.2010, 05:51     Побитовый сдвиг массива
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru