Модераторы: bsa
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> С++ вывести двоичное представление числа, инвертированного числа 
:(
    Опции темы
Kseni1995
Дата 15.5.2014, 19:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 8
Регистрация: 6.5.2014

Репутация: нет
Всего: нет



Здравствуйте! Помогите вывести "Инвертированный х" в двоичном виде именно с помощью функции printd, которая у меня описана. Задача то правильно написана, "Исходный х" тоже в двоичной выводит, а вот инвертированный не знаю как ...Подскажите!
Если что, вот задание: напишите программу invert(p,x,n), возвращающую значение х с инвертированными n-битами, начиная с позиции p ( остальные биты не меняются).
Код

#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;



PM MAIL   Вверх
tzirechnoy
Дата 15.5.2014, 20:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1173
Регистрация: 30.1.2009

Репутация: -1
Всего: 16



Код

#define l_szuint (sizeof(unsigned)*8)
#define uint_setbits(A) ((A)<l_szuint ? (~0 << (A)) : 0)
unsigned invert (unsigned x, int p, int n) {
 unsigned mask = uint_setbits(p) & ~uint_setbits(n+p);
 return x^mask;
}

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "C/C++: Для новичков"
JackYF
bsa

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, JackYF, bsa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Для новичков | Следующая тема »


 




[ Время генерации скрипта: 0.0752 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.