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

Побитовые операции (программа, которая интерпретирует старшие 3 бита как некоторое число n...) - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Создание дружественных классов http://www.cyberforum.ru/cpp-beginners/thread769686.html
1. Класс Сумка (цвет, содержимое, количество предметов в сумке); 2. Класс Дама (имя); Описание предметной области – дама может положить в сумку какой-либо предмет.
C++ Неправильно работает перегруженный оператор #include <iostream> using namespace std; class PhoneNumber { friend ostream &operator << (ostream &, const PhoneNumber &); friend istream &operator >> (istream &, PhoneNumber &); private: char areacode; char exchange; char line; http://www.cyberforum.ru/cpp-beginners/thread769669.html
C++ Cпособ передачи книги
Группа состоит из N человек. В ней каждый имеет N/2 друзей и не более К врагов. У одного из них есть книга, которую все хотят прочитать. Написать программу, реализующую способ передачи книги таким образом, чтобы она переходя от друга к другу побывала в руках у каждого не более одного раза и вернулась к владельцу.
C++ Расчет треугольника
В окно MFC вводятся длины двух сторон треугольника (1,2 строка) и величина угла между ними(3 строка). Найти третью сторону треугольника и вывести результат в четвертую строку. Предположительно должно быть так, но не знаю как сделать MFC:( #include "stdafx.h" #include "iostream" using namespace std; int _tmain(int argc, _TCHAR* argv)
C++ Произведение элементов в строках, которые не содержат нулевых элементов http://www.cyberforum.ru/cpp-beginners/thread769588.html
Задание: Реализуйте следующие задания своего варианта с использованием шаблона функции. Работа с двумерными массивами. Дана целочисленная прямоугольная матрица. Определить: Произведение элементов в тех строках, которые не содержат нулевых элементов. Вод код: #include <iostream> #include <conio.h> using namespace std; template <class proizv> // template - определеяем шаблон функции,...
C++ multimap: Сортировка значений в пределах одного ключа Добрый день. Каким образом можно отсортировать значения в пределах одного ключа в multimap? Без костылей. подробнее

Показать сообщение отдельно
vua72
410 / 410 / 83
Регистрация: 28.11.2010
Сообщений: 1,158
26.01.2013, 03:36     Побитовые операции (программа, которая интерпретирует старшие 3 бита как некоторое число n...)
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>
using namespace std;
int main()
{
    unsigned int a=0xafffffff;
    unsigned int mask=0xe0000000;
    unsigned int len=8*sizeof(int);
    unsigned int chislo=(a & mask)>>(len-3);
    unsigned int shifted=a;
    for (unsigned int i=0; i<len; ++i) /*rol shift*/
        (shifted & 0x10000000) ? (shifted <<= 1)|=1:(shifted <<= 1)|=0;
    cout <<hex<<chislo<<endl;
    cout <<hex<<shifted<<endl;
    return 0;
}
Добавлено через 21 минуту

Добавлено через 17 минут
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
#include <iostream>
#include <bitset>
using namespace std;
int main()
{
    unsigned int a=0xafaff4f5; //число
    unsigned int mask=0xe0000000; // старшие три разряда
    unsigned int mask1=0x10000000; // 28 разряд
    //unsigned int mask2=0x1fffffff; // старшие три разряда
    const unsigned int len=32;//8*sizeof(int);
    const unsigned int n=3;
    unsigned int chislo=(a & mask)>>(len-n); //получаем старшие 3 разряда
    unsigned int shifted=a;
    for (unsigned int i=0; i<len-n; ++i) { /*rol shift*/
        // if (i==0) (shifted & mask1) ? shifted|=mask1 : shifted&=mask2; // записываем в 29-31 значение 28 разряда 
        (shifted & mask1) ? (shifted <<= 1)|=1:(shifted <<= 1)|=0; // циклический сдвиг через 28 разряд
        cout <<bitset<len>(shifted)<<endl;
    }
    shifted=(shifted & ~mask)|(a & mask); // восстанавливаем 31-29 разряды
    cout<<"======================="<<endl;
    cout <<bitset<len>(a)<<endl;
    cout <<bitset<len>(mask)<<endl;
    cout <<bitset<len>(a & mask)<<endl;
    cout <<bitset<len>(mask1)<<endl;
    cout <<bitset<n>(chislo)<<endl;
    cout <<bitset<len>(shifted)<<endl;
    return 0;
}
 
Текущее время: 20:45. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru