Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/25: Рейтинг темы: голосов - 25, средняя оценка - 4.64
11 / 11 / 2
Регистрация: 16.08.2009
Сообщений: 434

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

23.03.2010, 23:13. Показов 4575. Ответов 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
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.03.2010, 23:13
Ответы с готовыми решениями:

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

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

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

4
 Аватар для Зоти Сергей
230 / 227 / 65
Регистрация: 18.12.2009
Сообщений: 316
24.03.2010, 00:31
так может попробовать:

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
11 / 11 / 2
Регистрация: 16.08.2009
Сообщений: 434
24.03.2010, 01:08  [ТС]
спасибо за пример
но код не работает

к примеру исходный массив такой
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
 Аватар для Зоти Сергей
230 / 227 / 65
Регистрация: 18.12.2009
Сообщений: 316
24.03.2010, 01:59
Код работает если по порядку к эл. обращаться. В исходном массиве 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
11 / 11 / 2
Регистрация: 16.08.2009
Сообщений: 434
24.03.2010, 05:51  [ТС]
Добавлено через 3 часа 5 минут
вобщем я разобрался как это записать

C++
1
memcpy(&massiv[0][0],&massiv[1][0],20*4-8);
но разве это и есть побитовый сдвиг массива ?
мне важно чтобы этот способ был самым быстрым
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.03.2010, 05:51
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru