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

Прокомментируйте пожалуйста програмку на побитовые операторы - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Проблемы с линковкой http://www.cyberforum.ru/cpp-beginners/thread605495.html
Доброго времени суток. Помогите разобраться в чем дело. В window.h объявляю структуру Window_Stuff и там же объявляю переменную window_stuff типа Window_Stuff. И получаю при сборке ошибку: 1>window.obj : error LNK2005: "struct Window_Stuff window_stuff" (?window_stuff@@3UWindow_Stuff@@A) уже определен в main.obj 1>D:\test\src\test\Debug\test.exe : fatal error LNK1169: обнаружен...
C++ Не могу разобраться с однонаправленным списком (есть прога) Помогите программку написать, пожалуйста Реализовать алгоритм работы с динамической структурой данных – однонаправленный список: элементы добавляются и удаляются с начала, просматриваются с конца списка. Элементы списка – вещественные числа. P.S. У меня есть программка, но там по-моему элементы добавляются и удаляются НЕ с начала, а с КОНЦА, проверьте, может че исправить можно??? ... http://www.cyberforum.ru/cpp-beginners/thread605488.html
двумерный массив C++
составить программу для вывода на экран двумерного массива из 4 столбцов и 5 строк целых чисел.Элементы массива заданы в программе
Написать программу на тему "файлы" C++
1)Дан файл, содержащий произвольный текст. Выяснить, чего в нем боль-ше: русских букв или цифр. 2)Дан файл Bibl, содержащий сведения о книгах. Сведения о каждой из книг — это фамилия автора, название и год издания. Найти название книг данного автора, изданных с I960 года.
C++ Поиск ошибки http://www.cyberforum.ru/cpp-beginners/thread605410.html
В чем может быть ошибка? никак не пойму.. Препод говорит что задача решена неверно. #include<iostream> using namespace std; #include <cmath> #define PI 3.14159265 double fsum(double x,double eps); int main() { double x, s, eps=1.0e-4;
C++ Сравнение элемента последовательности и параметра цикла Ребят, помогите в Си перевести как нибудь написать код, это сортировка вырожденным распределением: Создать цикл, максимальный параметр которого равен максимальному значению исходной последовательности. Затем каждый элемент исходной последовательности сравнивается с параметром цикла. Если элемент последовательности равен параметру цикла, то он записывается в результирующую последовательность. подробнее

Показать сообщение отдельно
kirya
-9 / 2 / 0
Регистрация: 01.06.2012
Сообщений: 87

Прокомментируйте пожалуйста програмку на побитовые операторы - C++

14.06.2012, 14:56. Просмотров 305. Ответов 0
Метки (Все метки)

Друзья прокоментируйте кто сможет каждую строку, что за что отвечает и т.д., что делает, вот задание и код:

ЧТО ТАКОЕ РОТАЦИЯ КСТАТИ????
6.Напишите программу ротации битов для заданных чисел, представленных в шестнадцатеричном виде, когда биты с самых крайних разрядов не теряются, а переносятся на противоположную сторону.



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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include <stdafx.h>
#include <conio.h>
#include <string.h>
 
// Прототипы функций
char *dec2hex (unsigned int var); 
unsigned int rotate (unsigned int value, int n);
 
const char basestr[16] = 
{'0','1','2','3','4','5','6','7','8','9',
'A','B','C','D','E','F'};
 
int main (void)
 {
int n;
unsigned int number, uns;
char *NUM1, str[128] = "0x", un[] = "u";
FILE *fid;
 
 
 
 
printf("\n The program for demonstration of bit-by-bit rotation \n of the numbers set in a hexadecimal kind\n");
 
printf("\n\t Enter the unsigned decimal: ");
    scanf_s("%u", &number);
    printf("\t Enter the number of bits of rotation: ");
    scanf_s("%d", &n);
 
//Для контроля перевода десятичного числа в шестнадцатеричное
    printf("\n\t Hexadecimal numbers: %X\n", number);
NUM1 = dec2hex(number);
strcat_s(str, 127, NUM1);
strcat_s(str, 127, un);
 
fopen_s(&fid,"temp.txt", "w");
fprintf(fid,"%s", str);
fclose(fid);
 
fopen_s(&fid,"temp.txt", "r");
fscanf_s(fid,"%x", &uns);
fclose(fid);
 
printf("\n\t After rotating %d-bits: %X\n", n, rotate(uns, n));
    printf("\n\n Press any key: ");
    _getch();
    return 0;
}
 
//Функция перевода десятичного числа в шестнадцатеричное
char *dec2hex(unsigned int var) {
int number[64];
int i, j, k = 0;
unsigned int base = 16;
char Hex[128], *PTR;
PTR = Hex;
 
do {
number[k] = var % base;
++ k;
var /= base;
} while (var != 0);
 
for (i = k-1, j = 0; i >= 0; --i, ++j) { 
Hex[j] = basestr[number[i]];
PTR[j] = Hex[j];
    }
PTR[j] = '\0';
 
    return (PTR);
} 
 
//Функция ротации числа влево или вправо
unsigned int rotate (unsigned int var, int n)
 {
unsigned int result, bits;
// Ограничение диапазона ротации
if (n > 0)
n = n % 32;
else
n = -(-n % 32);
if (n == 0)
result = var;
else
if (n > 0) // Ротация влево
{
bits = var >> (32 - n);
result = var << n | bits;
}
else // Ротация вправо
{
n = -n;
bits = var << (32 - n);
result = var >> n | bits;
}
return (result);
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru