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

Ошибка в функции strrchr - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Проверка порядка чисел в матрице http://www.cyberforum.ru/cpp-beginners/thread317552.html
Здравствуйте. Мучает такой вопрос: есть матрица 4 на 4, пользователь заполняет матрицу сам - заполняет числами от 1 до 16 ( строго в такой последовательности нужно). Программа расставляет эти числа в матрице соответственно. Мне нужна проверка того, правильно ли ввел числа пользователь. Т.е. вдруг он ввел числа не по порядку, а наоборот - 16,15,14... или вообще не те числа ( к примеру 24 27....75...
C++ Вычислить значение функции 2 Вычислить значение функции при заданных значениях параметров Заранее спасибо... http://www.cyberforum.ru/cpp-beginners/thread317550.html
Вопрос по исключениям в шаблонах классов C++
Кто подскажет как реализовать исключения в следующей задаче: Создать шаблонный класс, в котором создать одномерный массив и найти сумму элементов от n до m. Не могу понять как это сделать, кто может подсказать - буду благодарен, заранее СПАСИБО.
C++ Прошу помочь с программой составления заявок
Здравствуйте! Пожалуй начну о моей проблеме с начала. Работаю в крупной организации, занимаюсь снабжением производства ТМЦ и организацией ремонта изделий. Посредственно знаю PHP на уровне быдлокодера, абсолютно не знаком с ООП. Гуманитарное образование. По мере работы столкнулся с большой сложностью составления заявок на покупку, ремонт, запрос. Каждая заявка составляется в Word и...
C++ Ошибка в класе вектор http://www.cyberforum.ru/cpp-beginners/thread317523.html
У меня есть Класс вектор и в нем видает 3 ошибки error C2065: x: необъявленный идентификатор error C2065: y: необъявленный идентификатор error C2065: z: необъявленный идентификатор В перегрузке оператора произведение double operator*(vector a) { return a.x*x + a.y*y + a.z*z; }
C++ Даны два массива из указателей на строки Пожалуйста помогите!! Даны два массива из указателей на строки, последний элемент каждого массива равен NULL. Разработать функцию, получающую эти массивы и выводящую все строки, встречающиеся в обоих массивах и количество таких строк. Не хорошо влезать в чужие темы со своими задачами. Надо уважать других участников форума. подробнее

Показать сообщение отдельно
Алина_258
0 / 0 / 0
Регистрация: 10.06.2011
Сообщений: 11
10.06.2011, 21:38     Ошибка в функции strrchr
Добрый вечер!
помогите найти причину ошибки.
делала программу, считывающую текст из файла, сортирующую его по частоте слов, и записывающую обратно в файл.

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
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
//Объявите класс с именем text. Объявите функцию show(), функция сортирования текста по возрастанию.
//Текст можно вставить любой, а сортировать по количеству букв в слове от меньшего к большему ну или на оборот.
 
#include <ctype>
#include <fstream>
#include <windows>
#include <iomanip>
#include "stdafx.h"
#include <string.h>
#include <locale>
#include <stdio.h>
#include <iostream>
using namespace std;
 
 
class Text
{
private:
    char* str;
    int st3;
    int size;
    int k;
    char buffer;
public:  
    //Функция возврата массива символов 
    const char* Show(void);
 
    //Функция сортировки слов (по возрастанию)
    void SortWord(void);
 
    //Опаратор присваивание Text = char*;
    Text& operator= (char*);
    
    //Перегрузка конструктора копирование  по умолчанию
    Text& operator= (Text&);
    //Конструктор по умолчанию + инициализация переменной
    &Text(char* = "");    
    //Деструктор класса
    ~Text();
};
 
//Перегрузка конструктора копирование  по умолчанию
Text& Text::operator= (Text& Value)
{
    delete[] str;
    size = strlen(Value.str);
    str = new char[size+1];
    int k = 1;
    strcpy(str,Value.str);
    return *this;
}
 
//Конструктор по умолчанию + инициализация переменной
Text& Text::operator= (char *Value = "") 
{
    size = strlen(Value); // Запишим размер строки 
    str = new char[size+1]; //Выделим память под размер строки + нулевой символ 
    memset(str,0,size+1); //Обнулим выделеную память
    if (strlen(Value)>0)
    {
        strcpy(str,Value); //Скопируем Value - в память
    }
    int k=1 ;
};
 
//Функция возврата массива символов 
const char* Text::Show(void)
{
    return str;
}
 
//Функция сортировки слов (по возрастанию)
void Text::SortWord(void)
{        
 
    int Word = 0; //Счетчик слов
    char** ArrWord = new char*[size+1]; //Массив слов
    char *buffer = new char[size+1]; //Буферная переменная
    char *ptr = buffer; //Указатель на буферную переменную
    memset(buffer,0,size+1); //Обнулим буфрную переменную
 
    for (int i=0; i <= strlen(str); i++) //Обойдем по-символьно всю строку
    {
 
        int *l;
        char c = ' ';
         *l = strrchr(str[i], c);
        if (!l) //Если не пробел
        {
            *ptr++ = str[i]; //Пишим в буферную переменную и сдвигаем указатель
        }
        else 
            if (strlen(buffer)>0) //Если же управляющий или разделитель и длина буферной переменной >0
        {
            ArrWord[Word] = new char[size+1]; //Выделим память под слово
            strcpy(ArrWord[Word++],buffer); //Скопируем буферную переменную в слово
            memset(buffer,0,size+1); //Обнулим память буферной переменной
            ptr = buffer; //Поставим указатель на начало буферной переменной
        }
            else {}
 
    }
//  for (int i=0; i<size-1; i++) /*в цикле обходим все лова*/
//  {for (int j=1; j<size; j++)
//  {
//      char *s1  = &Text[i]::*str;
//      char *s2 = &Text[j]::*str;
//      {if (s1==s2) /*если слова под обоими объектами одинаковы */
//          &Text[i]::*k = &Text[i]::*k + 1;}/* количество повторений увеличиваем на 1*/
//  }}
 
    //const char *bufer= &buffer;
 
    int k[100] = {1};
 
    int str_len = strlen(buffer);
 
    int i;
    for(i = 0; i < str_len; i++)
    {
        k[(unsigned char)str[i]]++;
    }
 
 
    memset(str,0,size+1); //Обнулим строку
    //Сортируем слова по длине
 
    char Arrword[100];
 
    for (int i = 0; i<Word; i++)//Обойдем весь массив слов
    {
        int mkol=k[i];
        char Max = * ArrWord[i];
        int pos = i;
 
        for (int j=i; j<Word-1; j++) //Обойдем все слова с i 
        {
            if (mkol < k[j])
            {
                Max = * ArrWord[j];
                mkol = k[j];
                pos = j;
            }
 
        strcpy(buffer,ArrWord[j]); 
        strcpy(ArrWord[j],ArrWord[pos]);
        strcpy(ArrWord[pos],buffer);
        strcat(str,ArrWord[j]);
                }
        if ( (i+1) != Word) strcat(str," ");
    }
    for (int i = 0; i<Word; i++)
    {
        delete[] ArrWord[i];
    }
    delete [] buffer;
    delete [] ArrWord;
}
 
//Деструктор класса
Text::~Text()
{
    delete[] str;
}
 
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_ALL, "Russian");
    
    //Тестирование класса Text
    Text K("Обычный текс для проверки программы");
    K.SortWord();
    std::cout<<K.Show()<<std::endl;
return 0;
}
На этапе записи текста из файла в символьный массив, использую функцию :

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <ctype.h>
 
...
 
   for (int i=0; i <= strlen(str); i++) //Обойдем по-символьно всю строку
    {
 
        int *l;
        char c = ' ';
         *l = strrchr(str[i], c);
        if (!l) //Если не пробел
        {
            *ptr++ = str[i]; //Пишим в буферную переменную и сдвигаем указатель
        }
Компилятор выдаёт ошибку Ошибка 8 error C2665: strrchr: ни одна из 2 перегрузок не может преобразовать все типы аргументов k:\учёба\разработка и стандартизация\la3\la3\la3.cpp 88 la3


Где собака зарыта?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 13:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru