Версия для печати темы

Нажмите сюда для просмотра этой темы в обычном формате

Форум «Всё о Паскале» _ Ада и другие языки _ Кодирование символа

Автор: zloy_pes 25.10.2006 21:27

Помогите пожалуйста с такой задачей на Си: Вводится символ - нужно закодировать его, инвертировав значения бит на четных позициях (01110010 -> 11011000). Нужно использовать битовые поля.

Автор: volvo 25.10.2006 22:36

Извращение страшное, но работает (битовые поля тоже присутствуют)...
Тестировалось на 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;

}