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

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

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

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

23.03.2010, 23:13. Просмотров 2419. Ответов 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++;
}
Но это очень медленный способ, как сделать то же самое используя побитовый сдвиг массива, интересует самый быстрый вариант.
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.03.2010, 23:13
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Побитовый сдвиг массива (C++):

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

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

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

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

Побитовый сдвиг - 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...

Побитовый сдвиг - C++
Столкнулся с проблемой. У меня есть ключ - 0x1A305B98 Из него я получаю параметр путем int parm = (0x1A305B98 &gt;&gt; 20) &amp; 0x1F;// = 3 ...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Зоти Сергей
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;
1
nill
10 / 10 / 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
0
Зоти Сергей
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]);
0
nill
10 / 10 / 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);
но разве это и есть побитовый сдвиг массива ?
мне важно чтобы этот способ был самым быстрым
0
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; ...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
24.03.2010, 05:51
Ответ Создать тему
Опции темы

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