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

Инвертирование группы бит. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Определить, сколько в текстовом файле слов, состоящих не более чем из четырех букв http://www.cyberforum.ru/cpp-beginners/thread521500.html
Помогите написать программу, которая считывает текст из файла и определяет, сколько в нем слов, состоящих из не более чем четырех букв. Только в функции. Буду очень благодарен.
C++ Вычислить математическое ожидание, дисперсию и среднеквадратичное отклонение случайной величины Пусть массив X(N) - массив возможных значений некоторых случайных величин. Составить подпрограмму, которая вычисляет математическое ожидание (Mx), дисперсию (Dx) и среднеквадратичное отклонение (Fx) случайной величины X. M_x= \frac{\sum \limits_{i=1}^{N} X_i}{N} \qquad D_x=\frac{\sum \limits_{i=1}^{N} (X_i-M_x)^2}{N} \qquad F_x=\sqrt{D_x} Для передачи имени массива в подпрограмму ... http://www.cyberforum.ru/cpp-beginners/thread521494.html
Помогите организовать односвязный список! C++
Ребят, помогите пожалуйста организовать односвязный список и вывести его на экран... Вот пример той программы,которую я пытаюсь написать, только вот ничего у меня не получается с организацией и выводом... #include<iostream> #include<conio.h> #include<string.h> #include<stdlib.h> #include<stdio.h> #include<windows.h> using namespace std; struct sportsmen
C++ с++ , курсач, почнительная записка, Rational Roze.
Кто-нибудь делаал курсач по программированию?Я делаю в первый раз. нужна помощь в 4 задании и диаграммой в программе Rational Roze. Вот мой готовый курсач. Кто сможет, то помогите пожалуйста. http://www.cyberforum.ru/cpp-beginners/thread521184.html
C++ Цикл http://www.cyberforum.ru/cpp-beginners/thread521477.html
#include "stdafx.h" #include "conio.h" #include <iostream> #include <fstream> #include <string> using namespace std; struct main_file { int kc; int ku; int tn;
C++ как реализовать программу записная книжка на си++? Фамилия (ключевое поле, имеет уникальные, неповторяющиеся значения), Дата рождения (поле используется для отбора элементов), Номер телефона, Адрес. подробнее

Показать сообщение отдельно
-=ЮрА=-
Заблокирован
Автор FAQ
19.03.2012, 17:53     Инвертирование группы бит.
fasked, всё я тебя понял и так будет на много проще
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
#include <iostream>
using namespace std;
 
int M = sizeof(long)*8;
char * getBits(char * Bits, long val)
{
    _asm
    {
        mov eax,val
        mov ebx,Bits
        mov ecx,32
        lop:
        rol eax,1
            jc m1
            mov [ebx],30h
            jmp m2
            m1:
            mov [ebx],31h
            m2:
            inc ebx
        loop lop
        mov [ebx],0
    }
    return Bits;
}
 
char * invBits(char * Bits, long val, int P, int N)
{
    val <<= (M - P + N);
    strrev(Bits);
    Bits = Bits + P;
    _asm
    {
        mov eax,val
        mov ebx,Bits
        mov ecx,N
        lopPN:
        rol eax,1
            jc mPN1
            mov [ebx],31h
            jmp mPN2
            mPN1:
            mov [ebx],30h
            mPN2:
            inc ebx
        loop lopPN
    }
    return strrev(Bits - P);
}
 
long getNumFromBits(char * Bits)
{
    long pwr = 2;
    long val = (Bits[M - 1] - '0');
    for(int i = 1; i < M; i++)
    {
        val = val + pwr*(Bits[M - i - 1] - '0');
        pwr = pwr*2;
    }
    return val;
}
 
int main()
{
    int N, P;
    long val;
    char * Bits = new char[M + 1];
    cout<<"enter number : ";cin>>val;
    cout<<"enter N : ";cin>>N;
    cout<<"enter P : ";cin>>P;
    if(M < N + P + 1)
        cout<<"Chislo bitov k invertirovaniu prevoshodit razmer bitov v chisle\n";
    else
    {
        cout<<"input  bits in number  : "<<getBits(Bits, val)<<endl;
        cout<<"invert bits in number  : "<<invBits(Bits, val, P, N)<<endl;
        cout<<"number with invert bits: "<<getNumFromBits(Bits)<<endl;
    }
    system("pause");
    return 0;
}
PS:За годы асм подзабыл, но обещаю в скором времени буду приводить "простенький код для начинающих" - уверен сейчас алгоритм стал на много понятней
Миниатюры
Инвертирование группы бит.  
 
Текущее время: 15:45. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru