0 / 0 / 0
Регистрация: 25.04.2011
Сообщений: 12
|
||||||
1 | ||||||
Замена бит в числе формата float25.04.2011, 18:51. Показов 6696. Ответов 22
Метки нет (Все метки)
Доброго времени суток!
Помогите, пожалуйста, с лабораторной работой. Задача следующая: Вводим с клавы десятичное число формата float. Далее на экран надо вывести переведенное это число в двоичный код. После чего ввести 3 числа (первое и второе число могут быть от 0 до 31,т.к. бит всего 32, а третье число 0 или 1) И заменить с Х1 по Х2 бит нулями или единицами. Чтоб было понятнее пример: ввели какое-нибудь число и на экран вывелось 01000111100001 (короткий пример, не 32 бита) далее вводим 5 и 8. а также 0 и на экране после ввода и преобразования видим: 01000000000001 Надеюсь суть понятна P.S. Программируем мы на лабах в Си, не в Си++ P.P.S. Первую часть я написал сам (перевод числа из десятичной формы в двоичную, препод одобрил) вот эта часть:
0
|
25.04.2011, 18:51 | |
Ответы с готовыми решениями:
22
Сделать в числе n циклическую перестановку четных бит на k бит вправо Преобразовать 2 регистра 16 бит в 32 бита float Перестановка бит в числе Взять n-ный бит в числе |
25.04.2011, 20:02 | 2 | |||||
Ну вообще к вещественным числа битовые операции проводить неправильно Все равно в итоге используется грязный хак, с приведением к целочисленному указателю... Поэтому я приведу пример с целочисленными, а там уж разберетесь, в общем я просто оставлю это здесь...
2
|
0 / 0 / 0
Регистрация: 25.04.2011
Сообщений: 12
|
|
25.04.2011, 20:19 [ТС] | 3 |
0
|
0 / 0 / 0
Регистрация: 25.04.2011
Сообщений: 12
|
|
25.04.2011, 21:03 [ТС] | 5 |
Спасибо!)
Разбираюсь с лабой
0
|
0 / 0 / 0
Регистрация: 25.04.2011
Сообщений: 12
|
|
01.05.2011, 21:46 [ТС] | 6 |
а как поменять цвет тех битов которые мы поменяли ?
не всего выводимого числа, а именно тех бит которые заменили
0
|
0 / 0 / 0
Регистрация: 25.04.2011
Сообщений: 12
|
|
01.05.2011, 23:46 [ТС] | 8 |
постараюсь объяснить.
когда мы выводим уже преобразованное число то цвет тех символов что мы заменили будет например красный... чтоб было видно где была замена т.е. было например 000111110001110000 а стало 000111111111110000 и при выводе те "111" которые заменили "000" буду красными а остальные обычным цветом...
0
|
1069 / 848 / 60
Регистрация: 30.04.2011
Сообщений: 1,659
|
|
01.05.2011, 23:56 | 10 |
Если работаешь в Windows, то посмотри MSDN по консольным функциям WinAPI - там есть функция для изменения цвета выводимых в консоль сообщений...
2
|
0 / 0 / 0
Регистрация: 25.04.2011
Сообщений: 12
|
|
02.05.2011, 00:04 [ТС] | 11 |
Спасибо.
Спрошу тогда препода чтоб он сам при мне это сделал) Посмотрю как он выкрутится
0
|
1069 / 848 / 60
Регистрация: 30.04.2011
Сообщений: 1,659
|
|
02.05.2011, 00:10 | 12 |
Если среда от Борланд, то в conio.h есть функции... Точно не помню, но вроде типа textcolor() или что-то похожее...
1
|
0 / 0 / 0
Регистрация: 25.04.2011
Сообщений: 12
|
|
02.05.2011, 00:16 [ТС] | 13 |
textcolor такая функция есть...
цвет меняется... но меняется цвет всех выводимых символов... как сделать чтоб цвет менялся только тех символов что были изменены в ходе работы программы я не знаю
0
|
1069 / 848 / 60
Регистрация: 30.04.2011
Сообщений: 1,659
|
|
02.05.2011, 00:20 | 14 |
Нужно textcolor() вызывать в цикле для каждого символа в отдельности. В принципе, каждый символ можно своим цветом вывести.
А у вас надо просто в цикле проверять: если x1<i<x2? то цвет один, а иначе - другой
0
|
0 / 0 / 0
Регистрация: 25.04.2011
Сообщений: 12
|
|
02.05.2011, 00:27 [ТС] | 15 |
пробовал, не пашет)
может не так цикл задавал... ладно, завтра на свежую голову попробую Всем спасибо
0
|
0 / 0 / 0
Регистрация: 25.04.2011
Сообщений: 12
|
|
28.05.2011, 00:06 [ТС] | 16 |
И вот снова я с вопросом
препод дал небольшое дополнение к этой проге) Итак,вопрос: каким образом перевести из двоичной системы в десятичную посредством логических смещений? Суть придирки препода в том, что ему надо чтоб уже преобразованный двоичный код вывести десятичным числом, чтобы показать ему что мы действительно заменяли биты, а не просто что-то там намухлевали чтоб было понятно что мне надо узнать покажу пример: ввели число преобразовали его в двоичный код 0100001110000111110000 затем заменили биты,получили 0100001110000000000000 и теперь вот тот уже преобразованный код надо вывести как десятичное число...
0
|
1069 / 848 / 60
Регистрация: 30.04.2011
Сообщений: 1,659
|
|
28.05.2011, 00:46 | 17 |
Меняем Выводим: cout << P << endl; P - это имя переменной, где биты меняли...
0
|
0 / 0 / 0
Регистрация: 25.04.2011
Сообщений: 12
|
|
28.05.2011, 12:40 [ТС] | 18 |
Извините,а можно пояснить, пожалуйста, что сие означает?
cout << P << endl;
0
|
1069 / 848 / 60
Регистрация: 30.04.2011
Сообщений: 1,659
|
|
28.05.2011, 13:55 | 19 |
0
|
0 / 0 / 0
Регистрация: 25.04.2011
Сообщений: 12
|
|
28.05.2011, 15:16 [ТС] | 20 |
Т.е. сначала
cout << P << endl; А потом printf ? И что значат cout и endl?
0
|
28.05.2011, 15:16 | |
28.05.2011, 15:16 | |
Помогаю со студенческими работами здесь
20
Скольки бит выделяется в float и double под целую часть? Подсчитать количество нулевых бит в числе Найти количество единиц в числе с 5 по 10 бит Подсчитать число единичных бит в числе Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |