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

Перевести символ в двичный вид - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Не считывает с файла http://www.cyberforum.ru/cpp-beginners/thread613310.html
Друзья, вообщем написал программку, в которой вводятся шесть строк, в каждой по одному слову, затем вводишь символ и начинается сравнение: если символ этот совпадает с первой буквой какого либо слова в строке, то прога выводит эту самую строку. Только вот в чем дело, надо файл создать в проекте в папке самой, я создал, t.txt, в нем ввел шесть строк в каждой по слову, так вот программа должна уже...
C++ Namespace Мне посоветовали использовать функцию "using namespace std;". За что это строчка отвечает? Может есть еще какие-то функции, которые можно также использовать с тем же значением? http://www.cyberforum.ru/cpp-beginners/thread613304.html
C++ Как используют макросы?
Здраствуйте, в моем блоге форумчанин с ником Evg посоветовал использовать макрос для вот такой конструкции: i f ( k e y s & ( 0 x 1 << ( k e yW % 8 ) ) ) Объясните пожалуйста как это делается. Спасибо.
glfwGetKey C++
Какой тип возвращает? Какие биты значения за что отвечают? Различает ли одинаковые левые и правые кнопки? А цифры верхнего ряда отличает от цифр цифрового блока?
C++ Определить в тексте предложение с максимальным количеством слов http://www.cyberforum.ru/cpp-beginners/thread613274.html
Определить в тексте предложение с максимальным количеством слов. Вывести его на печать.
C++ например 317 должно вывести 3 гривны 17 копеек, 1 гривна 00 копеек Помогите подумать над алгоритмом, вот сама задача: Дано натуральное число, равное выраженной в копейках цене некоторого товара, например 317, 100 и т.д. Выразить цену в гривнах и копейках, например 3 гривны 17 копеек, 1 гривна 00 копеек. Число копеек всегда записывается двумя цифрами. Я так понимаю что числа надо разбить на лексемы только не знаю как это можно сделать ? подробнее

Показать сообщение отдельно
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,694
25.06.2012, 11:43     Перевести символ в двичный вид
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <conio.h>
 
struct node {
    char *p; // строка
    struct node *prev, *next;
} *head; // указатель на начало списка
 
void add(char *s) { // добавление в начало списка
    struct node *cur = (struct node *) malloc (sizeof(struct node));
    cur->p = s;
    if (head == NULL) {
        cur->prev = NULL;
        cur->next = NULL;
        head = cur;
        return;
    }
    cur->prev = NULL;
    cur->next = head;
    cur->next->prev = cur;
    head = cur;
}
 
void del(char *s) {
    struct node *cur = head;
    while (cur != NULL && cur->p != s)
        cur = cur->next;
    if (cur->next == NULL && cur->prev == NULL) { // если всего один элемент
        free(cur);
        head = NULL;
    } else if (cur->next == NULL) { // если на последнем месте,
        cur->prev->next = NULL;
        free(cur);
    } else if (cur->prev == NULL) { // если на первом месте
        cur->next->prev = NULL;
        head = cur->next;
        free(cur);
    } else { // иначе
        cur->prev->next = cur->next;
        cur->next->prev = cur->prev;
        free(cur);
    }
}
 
int test(char ch, int bit) { // возвращает значение заданного бита
    return ((ch >> bit) & 1);
}
 
void func(int bit) { // основная функция
    struct node *cur = head;
    int i;
    while (cur != NULL) {
        for (i = 0; i < strlen(cur->p); ++i)
            if (test(cur->p[i], bit) == 1) {
                del(cur->p);
                break;
            }
        cur = cur->next;
    }
}
 
void print() {
    //FILE *f;
    //f = fopen("out.txt", "w");
    struct node *cur = head;
    while (cur != NULL) {
        printf("%s\n", cur->p);
        cur = cur->next;
    }
    //fclose(f);
}
 
int main() {
    head = NULL;
    add("aaa");
    add("bbb");
    add("ccc");
    add("ddd");
    int bit;
    printf("Number of bit: ");
    scanf("%d", &bit);
    func(bit);
    print();
    return 0;
}
 
Текущее время: 05:36. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru