Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 3
1

Поразрядные операции (Запрограммировать изменение в с++ двухбайтного числа)

18.04.2013, 11:59. Просмотров 850. Ответов 2
Метки нет (Все метки)

Доброго времени суток!Если нетрудно,помогите)))Срочно нужна помощь в написании программы,очень-очень нужно...

задание:

Запрограммировать изменение в с++ двухбайтного числа (word) так, чтобы байт последовательно заполнялся сначала единицами, а затем – нулями справа налево.

1. Создать динамическую переменную и написать программу для работы с разрядами этой переменной в соответствии со своим вариантом задания (Запрограммировать изменение двухбайтного числа (word) так, чтобы байт последовательно заполнялся сначала единицами, а затем – нулями справа налево.
) двумя способами:
a. Используя операции поразрядного сдвига и поразрядные логические операции.
b. Используя структуру объединение (union) с использованием битовых полей.
2. При программировании обоими способами выводить данные на экран в десятичном и двоичном форматах. Выводить на экран размер задаваемой переменной/структуры.
3. Корректно создать и уничтожить динамическую переменную


Буду очень благодарна!!!
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
18.04.2013, 11:59
Ответы с готовыми решениями:

Поразрядные операции, получение максимального числа
Добрый вечер, помогите написать. В задаче даны два int-числа: N1 = АBCD и N2 = EFGH, где AB…GH...

Поразрядные операции
Нужно сделать программу деления целых чисел произвольной длины во внутреннем представлении с...

Поразрядные операции
Есть 16-е число, например N=0xC5D612F7, помогите убрать единицу в старшем бите у C и F, используя...

Поразрядные операции
Здравствуйте. Объясните, пожалуйста, есть задача: выполнить поразрядное «или» 0-5 разрядов В и...

2
498 / 348 / 93
Регистрация: 22.03.2011
Сообщений: 1,107
18.04.2013, 12:55 2
Лучший ответ Сообщение было отмечено Nadya95 как решение

Решение

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
#include <iostream>
 
template <typename T>
inline int is_bit_set(const T& value, size_t pos)
  {
  return (value & (1 << pos)) != 0;
  }
 
template <typename T>
void print_by_bites(const T& value)
  {
  int last = sizeof(T) * 8 - 1;
  for (size_t i = 0; i < last; ++i)
    std::cout << is_bit_set(value, i);
  std::cout << is_bit_set(value, last) << std::endl;
  }
 
struct Byte
  {
  unsigned _0 : 1;
  unsigned _1 : 1;
  unsigned _2 : 1;
  unsigned _3 : 1;
  unsigned _4 : 1;
  unsigned _5 : 1;
  unsigned _6 : 1;
  unsigned _7 : 1;
  };
 
union Short
  {
  Byte first;
  Byte second;
 
  short value;
  };
 
int main()
  {
  std::cout << "first method" << std::endl;
 
  short *word_1 = new short(0);
  
  for (int i = 0; i < sizeof(short) * 8; ++i)
    {
    *word_1 |= (1 << i);
    print_by_bites(*word_1);
    }
 
  for (int i = 0; i < sizeof(short) * 8; ++i)
    {
    *word_1 &= ~(1 << i);
    print_by_bites(*word_1);
    }
  delete word_1;
 
  std::cout << "second method" << std::endl;
  Short *word_2 = new Short;
  memset(word_2, 0, sizeof(Short)); //clrear
 
  /*it's 3*/
  word_2->first._0 = 1;
  word_2->first._1 = 1;
 
  std::cout << "value of word_2: " << word_2->value << std::endl;
  memset(word_2, 0, sizeof(Short)); //clrear
 
  /*it's 8*/
  word_2->first._3 = 1;
  std::cout << "value of word_2: " << word_2->value << std::endl;
 
  delete word_2;
 
  std::cin.get();
  return 0;
  }
0
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 3
25.04.2013, 06:16  [ТС] 3
Спасибо огромное)))))))))))))))))
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
25.04.2013, 06:16

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Поразрядные операции
Написать функцию, которая в числе x устанавливает 0 в n бит, находящихся справа от позиции p,...

поразрядные операции
помогите пожалуйста решить следущую задачу: даны два int-числа: N1 = АBCD и N2 = EFGH, где ...

Поразрядные операции
Даны два int-числа: N1 = ABCD и N2 = EFGH, где AB…GH – 16 – ричные цифры. Образовать long-число...

поразрядные операции
Народ, помогите пожалуйста решить задачу. Задание на скрине. Заранее спасибо.


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.