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

не могу избавится от ошибки - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Как эффективнее всего реализовать считывание нужной строки? http://www.cyberforum.ru/cpp-beginners/thread1209832.html
Всем привет! Нужно считать определенную строку в файле, допустим 5-ую. Как эффективнее всего это реализовать?
C++ Вычисление n!! пусть n-натуральное число.n!! означает 1*3*5*...*n для нечетного n.написать программу для вычисления n!! http://www.cyberforum.ru/cpp-beginners/thread1209830.html
C++ Найти тройки натуральных чисел, для которых выполняется равенство x^2-y=z^2
найти все такие тройки натуральных чисел x,y,z из интервала от 1 до 20,для которых выполняется равенство x^2-y=z^2
C++ Поиск двухзначных чисел
написать программу для поиска двухзначных чисел,таких,что если к сумме цифр этого числа прибавить квадрат этой суммы,то получится это число
C++ Добавление элемента в начало массива http://www.cyberforum.ru/cpp-beginners/thread1209792.html
Есть два массива, например (1,2,3,4,5) и (0,0,5,5,5), нужно превратить их в (0,1,2,3,4,5) и в (0,0,0,5,5,5), не знаю как реализовать. пробовал через memset, но не работает почему то. for (int i = 0; i < L1; i++){ bvector2 = bvector2; memset(bvector2, 0, 1);}; for (int i = 0; i < L1; i++){ bvector1 = bvector1; memset(bvector1, 0, 1);};
C++ Удалить из текста все слова заданной длины, начинающиеся с согласных букв. Из текста(русского) удалить все слова заданной длины, начинающиеся с согласных букв. Написать программу на С++. Очень нужно. подробнее

Показать сообщение отдельно
Andrey119
0 / 0 / 0
Регистрация: 30.10.2012
Сообщений: 36

не могу избавится от ошибки - C++

16.06.2014, 19:43. Просмотров 223. Ответов 4
Метки (Все метки)

Не знаю в чем проблема

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
#include "hash.h"
#include <iostream>
#include <string.h>
#include <fstream>
using namespace std;
 
int main(int argc, char *argv[])
{
    string a,b;
    HashDictionary A(13,11,7);
    fstream fs;
    fs.open (argv[1],fstream::in);
    cout<<endl;
    cout<<"Add words"<<endl;
 
    while(fs.good())
    {
        fs>>a>>b;
        if(fs.good())
            A.add(a,b);
    }
    A.output();
    fs.close();
    
    cout<<endl;
    cout<<"Find word"<<endl;
    fs.open (argv[1],fstream::in);
    while(fs.good())
    {
        fs>>a;
        cout<<A.findKey(a)<<" "<<a<<endl;
    }
cout<<A.findKey("blablabla")<<" blablabla"<<endl;
    fs.close();
    
    cout<<endl;
    cout<<"Existance of the word"<<endl;
    fs.open (argv[1],fstream::in);
    while(fs.good())
    {
        fs>>a;
        cout<<A.hasWord(a)<<" "<<a<<endl;
    }
    cout<<A.hasWord("blablabla")<<" blablabla"<<endl;
    fs.close();
    
    cout<<endl;
    cout<<"Delete word"<<endl;
    fs.open (argv[1],fstream::in);
    while(fs.good())
    {
        fs>>a>>b;
        if(fs.good())
            A.del(a);
    A.output();
    cout<<endl;   
    }
    fs.close();
    return 0;
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
#include <iostream>
#include <string.h>
using namespace std;
 
 
class HashDictionary{
private:
    //static const int P=7549;
    //static const int Q=4639;
    //static const int LENGTH=8193;
    
    const int P;
    const int Q;
    const int LENGT;
    string **dict;
    string **defin;
    const int keyLength;
    
    static int code(const char c);
    int findPos(const string &word) const;
public:
    HashDictionary(int length, int p, int q);
    int hash(const string &str)const;
    void add(const string &word, const string &def);
    bool hasWord(const string &word) const;
    void output();
    int findKey(const string &word)const;
    void del(const string &word);
};
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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
#include "hash.h"
#include <iostream>
#include <string.h>
using namespace std;
 
HashDictionary::HashDictionary( int length, int p, int q)
                :LENGT(length),P(p),Q(q),keyLength(13)
{
 dict=new string*[LENGT];
    defin=new string*[LENGT];
 memset(dict,0,sizeof(dict));
    memset(defin,0,sizeof(defin));
}
 
int HashDictionary::code(char c)
{
    int rez=-1;
    char alf[]="abcdefghijklmnopqrstuvwxyz";
    int i=0;
    while(alf[i]!=0)
    {
        if(alf[i]==c)
        {   rez=i;
            break;
        }
        else
            ++i;
    }
    return rez+1;
}
 
int HashDictionary::hash(const string &str)const
{
    int sum=0;
    for(int i=0; i<str.length(); ++i)
    {
        sum+=code(str[i])+i;
    }
    return (P*sum+Q)%keyLength;
}
 
int HashDictionary::findPos(const string &word)const
{
    int i=hash(word);
    for(int counter=0; counter<LENGT; ++counter)
    {
        if(dict[i]==NULL || *dict[i]==word)
            return i;
        else if(++i==LENGT)
            i=0;
    }
    return -1;
}
 
 
void HashDictionary::add(const string &word, const string &def)
{
    if(word.length()>keyLength)
        return;
    int i=findPos(word);
    if(i==-1)
        return;
    if(dict[i]==NULL)
    {
        dict[i]= new string();
        *dict[i]=word;
        defin[i]=new string();
        *defin[i]=def;
    }
}
 
bool HashDictionary::hasWord(const string &word) const
{
    int i=hash(word);
    for(int counter=0; counter<LENGT; ++counter)
    {
        if(dict[i] && *dict[i]==word)
            return true;
        else if(++i==LENGT)
            i=0;
    }
    return false;
}
 
 
void HashDictionary::output()
{
    cout<<"Index Hash Key Definition"<<endl;
    for(int i=0; i<LENGT; ++i)
    {
        if(dict[i])
            cout<<i<<" "<<hash(*dict[i])<<" "<<*dict[i]<<" "<<*defin[i]<<endl;
    }
}
 
void HashDictionary::del(const string &word)
{
    int i=hash(word);
    for(int counter=0; counter<LENGT; ++counter)
    {
        if(dict[i] && *dict[i]==word)
        {
            delete dict[i];
            dict[i]=0;
            delete defin[i];
            defin[i]=0;
            return;
        }
        else if(++i==LENGT)
            i=0;
    }
}
 
 
int HashDictionary::findKey(const string &word)const
{
    int i=hash(word);
    for(int counter=0; counter<LENGT; ++counter)
    {
        if(dict[i] && *dict[i]==word)
            return i;
        else if(++i==LENGT)
            i=0;
    }
    return -1;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru