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

Реализовать функцию invert(p,x,n), возвращающую значение х с инвертированными n-битами, начиная с позиции p - C++

Восстановить пароль Регистрация
 
Kseni1995
0 / 0 / 0
Регистрация: 03.05.2014
Сообщений: 29
17.05.2014, 17:56     Реализовать функцию invert(p,x,n), возвращающую значение х с инвертированными n-битами, начиная с позиции p #1
Здравствуйте! Помогите пожалуйстаа вывести "Инвертированный х" в двоичном виде именно с помощью функции printd, которая у меня описана. Задача то правильно написана, "Исходный х" тоже в двоичной выводит, а вот инвертированный не знаю как ...Подскажите!
Если что, вот задание: напишите программу invert(p,x,n), возвращающую значение х с инвертированными n-битами, начиная с позиции p ( остальные биты не меняются).

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
#include "stdafx.h"
#include <iostream>
#include <conio.h>
using namespace std;
 
 
unsigned invert(unsigned x, int p, int n)
{
    int count = sizeof(x) * 8;
    unsigned t = ((unsigned) ~0 << (p - 1)) >> (count - n) << (count - n - p + 1);
    return (~x & t) | (x & ~t);
}
 
void printd(int val, int base = 10)
{
    if(val < 0)
    {
        cout.put ('-');
        printd (-val, base);
    }
    else
    {
        if(val / base > 0) printd (val / base, base);
        int r = val % base;
        if(r < 10) cout.put ('0' + r);
        else cout.put ('A' + r - 10);
    }
}
 
int main()
{
    setlocale(LC_ALL,"Russian");
    unsigned x;
    int p, n;
    cout << "Введите x в шестнадцатеричной: ";
    cin >> hex >> x;
    cout << "Введите p позицию и число инвертированных битов n: ";
    cin >> dec >> p >> n;
    cout << "Исходный x: "<< endl;
    printd(x,2);
    cout<< "\nИнвертированный x: " << invert(x, p, n) << endl;
    _getch();
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.05.2014, 17:56     Реализовать функцию invert(p,x,n), возвращающую значение х с инвертированными n-битами, начиная с позиции p
Посмотрите здесь:

Установка L символов строки s в значение t, начиная с позиции n C++
Вычислить сумму ряда с позиции N до позиции M. Функцию вычисления суммы реализовать рекурсивно. C++
разработать рекурсивную функцию не возвращающую значение C++
C++ Разработать рекурсивную функцию, возвращающую значение
C++ Написать функцию, которая возвращает число, полученное из целого числа x, в котором единицы установлены в n разрядов, начиная с позиции p (крайний пра
Разработать рекурсивную функцию, возвращающую значение: C++
Установка l символов строке s, начиная с позиции n, в значение t C++
Использовать функцию, возвращающую значение F (x) C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 15:13. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru