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

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

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

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

23.03.2010, 23:13. Просмотров 2393. Ответов 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++
Столкнулся с проблемой. У меня есть ключ - 0x1A305B98 Из него я получаю параметр путем int parm = (0x1A305B98 &gt;&gt; 20) &amp; 0x1F;// = 3 ...

Побитовый сдвиг - C++
Непонятна часть программы с 24 по 45 строку. Помогите разобраться, пожалуйста. #include &lt;iostream&gt; using namespace std; const int...

Побитовый сдвиг - C++
Выполнение данного кода приравнивает asd к нулю. Хотя должно к единице, судя по моим вычислениям. char asd = 10 &amp; 2 &gt;&gt; 1; 1010 ...

Побитовый сдвиг - C++
есть допустим переменная unsigned char data = 0b10111011; Как можно сделать за 4 шага по битовый сдвиг на двух половинах как...

Побитовый сдвиг - C++
Добрый день, помогите пожалуйста с побитовым сдвигом вправо, не получается добиться верной работы, укажите на ошибку пожалуйста, спасибо! ...

Побитовый сдвиг - C++
#include &lt;iostream&gt; using namespace std; int main(int argc, char** argv) { int a,b,c,i; cin &gt;&gt;a; cin &gt;&gt;c; cin &gt;&gt;b; do...

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Зоти Сергей
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]);
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.03.2010, 05:51     Побитовый сдвиг массива
Еще ссылки по теме:

Побитовый сдвиг влево и вправо - C++
Что выполнится быстрее - сдвиг влево или сдвиг вправо? И как замерить время выполнения каждой из операций в коде? Добавлено через 2...

Как происходит побитовый сдвиг? - C++
for(int i = 0; i &lt; 10; i ++){ if (i &amp; (1 &lt;&lt; j)) cout &lt;&lt; i &lt;&lt; endl; }

Как реализовать правильный побитовый сдвиг? - C++
Всем привет! У меня тупик в неожиданном месте) Я имею пару чаров и должен из них собрать int: char a1 = 224; char a2 = 18; ...

Не могу понять, как работает побитовый сдвиг - C++
Есть вот такой код: int invar, wv1, wv2, et, yt, resv; invar = 14; wv1 = invar &gt;&gt; 4; printf(&quot;%i\n&quot;, wv1); wv1 = wv1 &lt;&lt; 28; ...

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

Получить введенное значение используя операции сложения, вычитания и побитовый сдвиг влево - C++
#include &lt;iostream&gt; #include &lt;cmath&gt; using namespace std; int main() { int N; //количество чисел cout &lt;&lt; &quot;Amount of numbers:...


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

Или воспользуйтесь поиском по форуму:
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