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

битовые поля!! - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Текущие дату в int http://www.cyberforum.ru/cpp-beginners/thread43222.html
Необходимо получит текщие год, месяц, число и перевести их в int каждый. Получит, то получаю, а как перевести? #include <time.h> #include <iostream> using namespace std; void main() { char* s = (char*)malloc(100);
C++ Убрать ненужное Программисты!Подскажите пожалуйста, как убрать в консоли, в Visual Studio 2005, в конце программы фразу "Для продолжения нажмите любую клавишу",которая вылазит после нажатия клавиши ENTER,я пробывал вконце прописать cin.get(); , эта фраза исчезает при выводе, но при нажатии на энтер, всё равно появляется. Не скажите как избавится от этой фразы. Зараннее благодарю. http://www.cyberforum.ru/cpp-beginners/thread43209.html
C++ бинарный поиск
Задали реализовать бинарный поиск в упорядоченном массиве.Уже пол дня творю,3 листа исписал и ничего не получается. Вот пример поиска который нам показали //Метод Выбора for(i=0;i<n-1;i++) { min=i; for(j=i+1;j<n;j++) { if(a<a)min=j;
C++ Borland C++ 3.11
Помогите пожалуйста используя Borland C++ 3.11 Вот задание в формате doc: http://********.net/download/5471.5da3b4a2850227f9306fd415c/Praktska_Ci.do_.html
C++ Написать программу меняющую в двумерном массиве строки со столбцами, и еще некоторые http://www.cyberforum.ru/cpp-beginners/thread43174.html
1) Написать программу меняющую в двумерном массиве строки со столбцами 2) Разработать структуру, осуществляющую чтение с диска и выводящую на монитор фамилии учеников с указанием номера последнего выполненного задания. Затем с клавиатуры добавляется оценка за последнее задание 3)Написать программу вычисления амплитуды R зубца в ЭКГ 4)Составить процедуру вычисления квадрата разности двух...
C++ бинарное древо (удаление) Ребята выручайте не как не могу понять алгоритм удаления из дерева. Кто нить может описать подробные коментарии к удалению узла у которого есть оба поддерева или в нем где есть ошибка. Зарание спс. struct tree *dtree(struct tree *root, char key) { struct tree *p,*p2; if(!root) return root; /* вершина не найдена */ if(root->info == key) { /* удаление корня */ ЭТО ПОНЯТНО подробнее

Показать сообщение отдельно
TimoshkaXXX
0 / 0 / 0
Регистрация: 15.04.2009
Сообщений: 49
07.07.2009, 00:28     битовые поля!!
добрый вечер!
имеется класс представления битовых полей:
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
#ifndef HTBITFIELDS
#define HTBITFIELDS
 
#include <iostream>
using namespace std;
 
#include "Cmystring.h"
 
class TBitFields
{
  private:  
      unsigned* bfields;    // массив размещения битовых полей
      int size;         // размер bfields 
      int fCount;       // к-во полей
      Cmystring* fNames;    // имена полей
      char*  fSizes;        // размеры полей
      char*  fIndex;        // индексы полей в bfields
      char*  fPos;      // позиции полей в bfields
  public:
      // Конструкторы ---------------------------------
      TBitFields (int _fCount, Cmystring* _fNames, char* _fSizes);                  
      // Деструктор -----------------------------------
      ~TBitFields (void);     
      // установить значение поля
      void SetField(const Cmystring _fName, unsigned fVals);    
      // получить значение поля
      unsigned GetField(const Cmystring _fName) const;  
//    unsigned GetField(const Cmystring _fName) const;  
      // прибавить значение к полю
      void AddField(const Cmystring _fName, unsigned fVals);    
      unsigned& operator[] (const Cmystring _fName);
//    unsigned operator[] (const Cmystring _fName);
      TBitFields& operator= (unsigned num);
      TBitFields& operator[] (const Cmystring _fName);
      friend ostream& operator<<(ostream& stream, const TBitFields& _bf);
      //friend istream& operator>>(istream& stream,       TBitFields& _bf);
  
private:
    int _findField(const Cmystring _fName) const;
 
};
 
#endif
который внутри каждого элемента массива unsigned'ов может хранить заданное число битовых полей заданной длины.
все объявленные здесь функции у меня работают, но нужно еще перегрузить операции присваивания и индексации так чтобы выполнялся следующий код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
int main()
{
    setlocale(LC_CTYPE, "Russian");
 
    Cmystring fnames[] = { "a", "b", "c", "d", "e", "f", "g", "h" };
    char      fsize[]  = {   8,  16,   8,  16,  16,   8,   8,   8 };
    int fcount = 8;
 
    TBitFields bf(fcount, fnames, fsize);
 
    bf["a"] = 1;    cout << "a = " << bf["a"] << endl;
    bf["b"] = 2;    cout << "b = " << bf["b"] << endl;
    bf["c"] = 3;    cout << "c = " << bf["c"] << endl;
    bf["d"] = 4;    cout << "d = " << bf["d"] << endl;
    bf["e"] = 5;    cout << "e = " << bf["e"] << endl;
    bf["f"] = 6;    cout << "f = " << bf["f"] << endl;
    bf["g"] = 7;    cout << "g = " << bf["g"] << endl;
    bf["h"] = 8;    cout << "h = " << bf["h"] << endl;
подскажите пожалуйста как это сделать??

зы описание методов класса:
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
98
99
100
#include "TBitFields.h"
 
TBitFields::TBitFields (int _fCount, Cmystring* _fNames, char* _fSizes)
{
    fCount = _fCount;//количество полей
    fSizes = new char[fCount]; //размеры полей
    fNames = new Cmystring[fCount]; //имена полей
    int s = 0;
    fIndex =  new char[fCount];//смещение от начала страницы 
    fPos = new char[fCount]; //номер элемента массива bfields в котором надоится поле
    for (int i = 0; i < fCount; i++)
    {
        fNames[i] = _fNames[i]; //копируем имена полей и их размеры
        fSizes[i] = _fSizes[i];
        s += fSizes[i]; //сумма размеров всех полей
    }
    fIndex[0] = 0;//для первого поля индекс равен 0
 
    for (int i = 1; i < fCount; i++)
    {
        fIndex[i] = fIndex[i - 1] + fSizes[i - 1]; //для каждого последующего поля индекс равен индексу предыдущего + размер ..                                                         //предыдущего поля
    }
    int k = 0;
    for (int i = 0; i < fCount; )
    {
        while (fIndex[i] < sizeof(unsigned) * (k + 1))//пока индекс поля меньше смещения текущего элемента bfields относительно начала, 
            fPos[i++] = k;                             //позиция данного поля равна индексу текущего элемента bfileds
        k++;
    }
    size = s / sizeof(unsigned) + 1;
    bfields = new unsigned[size];
    
}
TBitFields::~TBitFields()
{
    delete [] bfields;
    delete [] fSizes;
    delete [] fNames;
    delete [] fIndex;
    delete [] fPos;
}
void TBitFields::SetField(const Cmystring _fName, unsigned fVals)//установить значение поля
{
    for (int i = 0; i < fCount; i++)
    {
        if (fNames[i] == _fName)
        {
            unsigned tmp =  ~0;
            int left = fIndex[i] - fPos[i] * sizeof(unsigned);
            int right = left + fSizes[i] - 1;
            tmp = ~(((tmp << 32 - left) >> 32 - left + right) << right);
            bfields[fPos[i]] &= tmp;
            bfields[fPos[i]] |= fVals << right;
            break;
        }
    }
}
unsigned TBitFields::GetField(const Cmystring _fName) const
{
    unsigned res = 0;
    for (int i = 0; i < fCount; i++)
    {
        if (fNames[i] == _fName)
        {
            unsigned tmp =  ~0;
            int left = fIndex[i] - fPos[i] * sizeof(unsigned);
            int right = left + fSizes[i] - 1;
            tmp = (((tmp << 32 - left) >> 32 - left + right) << right);
            res = bfields[fPos[i]] & tmp >> right;
            break;
        }
    }
    return res;
}
void TBitFields::AddField(const Cmystring _fName, unsigned fVals)
{
    unsigned tmp = GetField(_fName);
    SetField(_fName, tmp + fVals);
}
ostream& operator<<(ostream& stream, const TBitFields& _bf)
{
    for (int i = 0; i < _bf.fCount; i++)
    {
        stream << _bf.fNames[i] << " = " << _bf.GetField(_bf.fNames[i]) << endl;
    }
    return stream;
}
/*unsigned TBitFields::operator[] (const Cmystring _fName)
{
    
}*/
unsigned& TBitFields::operator [](const Cmystring _fName)
{
    unsigned result = GetField(_fName);
    return result;
}
TBitFields& TBitFields::operator= (unsigned num)
{
    return *this;   
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 03:30. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru