Помощь - Поиск - Пользователи - Календарь
Полная версия: Кодирование символа
Форум «Всё о Паскале» > Современный Паскаль и другие языки > Ада и другие языки
zloy_pes
Помогите пожалуйста с такой задачей на Си: Вводится символ - нужно закодировать его, инвертировав значения бит на четных позициях (01110010 -> 11011000). Нужно использовать битовые поля.
volvo
Извращение страшное, но работает (битовые поля тоже присутствуют)...
Тестировалось на Turbo C, возможно на других компиляторах не пойдет (я не знаю, насколько переносима "склейка" - она же ##)

#include <conio.h>
#include <stdio.h>

#define bit_number(x) _##x
#define invert(x) (Cvt.bits.bit_number(x))=(!(Cvt.bits.bit_number(x)));

typedef struct _BitField {
unsigned int _0:1;
unsigned int _1:1;
unsigned int _2:1;
unsigned int _3:1;
unsigned int _4:1;
unsigned int _5:1;
unsigned int _6:1;
unsigned int _7:1;
} BitField;

typedef union _Convert {
BitField bits;
char ch;
} Convert;

int main() {
char s[10];
Convert Cvt;

Cvt.ch = getch();
printf("init value = %c(%d)\n", Cvt.ch, Cvt.ch);
/* Cvt.ch = (char)114; */
invert(1);
invert(3);
invert(5);
invert(7);

printf("encoded value = %c(%d)\n", Cvt.ch, (((int)Cvt.ch) & 0xFF));
return 0;

}
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.