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

10->2 + сдвиг+инвертация - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ рекурсивная(( http://www.cyberforum.ru/cpp-beginners/thread183658.html
Proc67. Описать рекурсивную функцию MinRec(A,N)1|MaxRec(A,N)2 вещественного типа, которая находит минимальный1|максимальный2 элемент вещественного массива A размера N, не используя оператор цикла. С помощью функции MinRec1|MaxRec2 найти минимальные1|максимальные2 элементы массивов A, B, C размера NA, NB, NC соответственно. # include <iostream> # include <conio.h> using namespace std; ...
C++ Ошибка компиляции Не могу скомпелировать код: #include <iostream.h> int main() { string s = ""; system("pause >> void"); } http://www.cyberforum.ru/cpp-beginners/thread183632.html
C++ Аппроксимация функции и оценка погрешности
Составить программу аппроксимации функцией y=ax^2 +bx+c и оценки погрешности аппроксимации. решить на с++.
Интегрирование уравнения генератора Ван дер Поля C++
Составить программу интегрирования уравнения генератора Ван дер Поля x''-(a-x^2)*x'+x=0 методом Эйлера для случая а=5. ( '-производная, или точки стоящие над х) решить на с++.
C++ Заменять первый положительный элемент массива средним арфиметическим http://www.cyberforum.ru/cpp-beginners/thread183625.html
составить программу,которая в одномерном массиве f,m<=11 заменяет первый положительный элемент средним арфиметическим всех отрицатльных элементов массива.исходный и преобразованный массивы вывести в поясняющим текстом))
C++ Численое интегрирование функции Составить программу численого интегрирования функции y=1/x на интервале методом трапеции. Оценить точность интегрирования. решить на с++. подробнее

Показать сообщение отдельно
JerryJackson
50 / 6 / 1
Регистрация: 15.07.2010
Сообщений: 112

10->2 + сдвиг+инвертация - C++

29.10.2010, 22:30. Просмотров 824. Ответов 1
Метки (Все метки)

Народ пожалуйста подскажите есть ли у меня ошибки в лабе


Написать программу на языке C++, читающую со стандартного ввода 4 деся-
тичных числа x, y,m, n. Все смещения будут указываться начиная с младшего
бита, начиная с 0.
В числах x, y младшие m из x заменить на старшие m бит из y, потом
инвертировать 5 младших бит в x.
Программа должна вывести все исходные данные в десятичном виде,
исходные и полученные значения x, y в двоичном виде в столбик, причём
справа от числа должно быть выведено имя соответствующей переменной.
В программе не должно быть более одного цикла. Не следует использовать
классы и библиотеки для работы с битовыми объектами. Рекомендуется не
изменять исходные переменные, следует определить выходные и временные
переменные. Программа должна быть корректной вне зависимости от коли-
чества бит в целом числе на данной архитектуре.




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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
 #include <iostream.h>
 
using namespace std;
void bit_print(int);
void bit_move(unsigned int,unsigned int,unsigned int);
void bit_invert(unsigned int);
 
 
int main()
{
    int x,y,m,n;
cout << "Input x" << endl;
cin >> x;
cout << "X=";
bit_print(x);
cout << endl;
cout << "Input y" << endl;
cin >> y;
cout << "Y=";
bit_print(y);
cout << endl;
cout << "Input m" << endl;
cin >> m;
cout << "M=" << m;
 
cout << endl;
cout << "Input n" << endl;
cin >> n;
cout << "N=" << n;
 
cout << endl;
cout << "Move bits X,M,Y=";
cout << endl;
bit_move(x,m,y);
 
cout << endl;
cout << "Invert X=";
cout << endl;
bit_invert(x);
cout << endl;
 
}
void bit_print(int a)
{
    int i;
    unsigned int maska;
    int s;
    s=sizeof(int)*8;
    maska=1;
    maska = maska<<(s-1);
    for(int i=(sizeof(int)*8);i>0;i--)
    {
        if((a&maska)==maska)
            cout<<"1";
        else
            cout<<"0";
        maska>>=1;
    }
 
    return;
}
void bit_move(unsigned int a_x, unsigned int m, unsigned int b_y)
{
 
    unsigned int f=0,j=0,xy_res;
    j=a_x<<(sizeof(int)*8-m); //x сдвинули влево (обнулили x)
    bit_print(j);
    cout << endl;
    f=b_y<<m;//y сдвинули влево на m (обнулили m битов y)
    f=f>>m;//y сдвинули вправо на m (на месте 1 получили 0)
    bit_print(f);
    cout << endl;
    xy_res=j|f; //xy_res=a_x|j|f результат замены между x и y
    bit_print(xy_res);
    cout << endl;
    return;
}
void bit_invert(unsigned int x)
{
    unsigned int f_x;
int s;
s=sizeof(int)*8;
f_x=~x;//инверируем x
x=x<<m;//сдвигаем влево
x=x>>m;//сдвигаем вправо
f_x=>>s-m;
f_x=<<s-m;
x=x|f_x;
bit_print(x);    
}
Заранее спасибо.

Добавлено через 45 секунд
пожалуйста помогите с функцией сдвига и инвертацией
а то я запутался
не понятно что они выпоняют
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru