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

Ошибка при компиляции - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Random: генерируются одни и те же значения http://www.cyberforum.ru/cpp-beginners/thread309397.html
Написала программу, в которой нужно использовать генерацию случайных чисел, в итоге при каждом запуске генерируются одни и те же числа. В чем может быть причина, подскажите, пожалуйста. Если кому понадобится, могу выложить код. Спасибо.
C++ SendMessage(Hwnd, WM_SYSCOMMAND, SC_MAXIMIZE, 0); Добрый день) Разворот окна на весь экран осуществляется следующим кодом (Hwnd - дескриптор окна): SendMessage(Hwnd, WM_SYSCOMMAND, SC_MAXIMIZE, 0); вот прочитал в инете что функция SendMessage разворачивает окно... решил попробовать.... а программа не компилируется ( в какой библиотеке заложена эта функция? http://www.cyberforum.ru/cpp-beginners/thread309396.html
Строки, нужна подсказка. C++
Дана строка, состоящая из слов, разделенных любым количеством пробелов. Напишите программу, которая находит все слова, в которых буква ”а” встречается более чем один раз. Накодил такую штуку #include <iostream.h> #include <string.h> void main() { char str; cin>>str; char *ps = strstr(str, "a"); if (ps != NULL)
C++ построение блок-схемы
помогите пожалуйста нарисовать блок схемы по коду программ.. к сожалению с их построением проблемы(( #include "stdafx.h" #include <stdlib.h> #include <stdio.h> #include <iostream> using namespace std; int main() { int flag = 1;
C++ throw, try, catch http://www.cyberforum.ru/cpp-beginners/thread309360.html
Пожалуйста, помогите разобраться в том, что это такое, и как его правильно использовать. Где можно об этом почитать? P.S. только начал изучать ООП.
C++ как извлеч цифру господа програмисты есть такой вопрос допустим есть файл .txt и внём записанно определённое число,как это число можно присвоить переменной? Заранее всем огромное спасибо!!! подробнее

Показать сообщение отдельно
UKOL
112 / 64 / 7
Регистрация: 17.11.2009
Сообщений: 258

Ошибка при компиляции - C++

31.05.2011, 19:18. Просмотров 640. Ответов 1
Метки (Все метки)

Прошу вашей помощи, не могу запустить программу, как устранить ошибки?

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
// sllist.h
#ifndef SLLIST_H__
#define SLLIST_H__
 
#define SL_SUCCESS    0
#define SL_NO_MEM     1
#define SL_ZERO_SIZE  2
 
 
typedef struct SLLIST
{
  int Tag;
  struct SLLIST *Next;
  void *Object;
  size_t Size;
} SLLIST;
 
/* Add new item immediately after current item */
int SLAdd(SLLIST **Item, int Tag, void *Object, size_t Size);
 
/* Add item to front of list. Care: if you pass
 * this function any node other than the first,
 * you will get Y-branches in your list:
 *
 *    oldroot-->-
 *               \  
 *                >->-passeditem-->-->--oldnext
 *               /
 *    newitem-->-
 *
 * This would be a Bad Thing.
 */
int SLFront(SLLIST **Item, int Tag, void *Object, size_t Size);
 
/* Add new item right at the end of the list */
int SLAppend(SLLIST **Item, int Tag, void *Object, size_t Size);
 
/* Replace existing data */
int SLUpdate(SLLIST *Item, int NewTag, void *NewObject, size_t NewSize);
 
/* Retrieve data from this node */
void *SLGetData(SLLIST *Item, int *Tag, size_t *Size);
 
/* Delete this item. Returns pointer to
 * next item - caller's responsibility
 * to maintain list integrity.
 */
SLLIST *SLDeleteThis(SLLIST *Item);
 
/* Delete item immediately following
 * the one passed in. List integrity
 * maintained automatically.
 */
void SLDeleteNext(SLLIST *Item);
 
/* Destroy the entire list */
void SLDestroy(SLLIST **List);
 
/* Call func(Tag, ThisItem, Args) for each item */
int SLWalk(SLLIST *List, int(*Func)(int, void *, void *), void *Args);
 
#endif
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
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
// sllist.cpp
#include <stdlib.h>
#include <string.h>
#include <assert.h>
 
#include "sllist.h"
 
int SLAdd(SLLIST **Item,
          int Tag,
          void *Object,
          size_t Size)
{
  SLLIST *NewItem;
  int Result = SL_SUCCESS;
 
  assert(Item != NULL);
 
  if(Size > 0)
  {
    NewItem = malloc(sizeof *NewItem);
    if(NewItem != NULL)
    {
      NewItem->Tag    = Tag;
      NewItem->Size   = Size;
      NewItem->Object = malloc(Size);
 
      if(NewItem->Object != NULL)
      {
        memcpy(NewItem->Object, Object, Size);
        /* Handle empty list */
        if(NULL == *Item)
        {
          NewItem->Next = NULL;
          *Item = NewItem;
        }
        else /* Insert just after current item */
        {
          NewItem->Next = (*Item)->Next;
          (*Item)->Next = NewItem;
        }
      }
      else
      {
        free(NewItem);
        Result = SL_NO_MEM;
      }
    }
    else
    {
      Result = SL_NO_MEM;
    }
  }
  else
  {
    Result = SL_ZERO_SIZE;
  }
 
  return Result;
}
 
int SLFront(SLLIST **Item,
            int Tag,
            void *Object,
            size_t Size)
{
  int Result = SL_SUCCESS;
 
  SLLIST *p = NULL;
 
  assert(Item != NULL);
 
  Result = SLAdd(&p, Tag, Object, Size);
  if(SL_SUCCESS == Result)
  {
    p->Next = *Item;
    *Item = p;
  }
 
  return Result;
}
 
int SLAppend(SLLIST **Item,
             int Tag,
             void *Object,
             size_t Size)
{
  int Result = SL_SUCCESS;
  SLLIST *EndSeeker;
 
  assert(Item != NULL);
 
  if(NULL == *Item)
  {
    Result = SLAdd(Item, Tag, Object, Size);
  }
  else
  {
    EndSeeker = *Item;
    while(EndSeeker->Next != NULL)
    {
      EndSeeker = EndSeeker->Next;
    }
    Result = SLAdd(&EndSeeker, Tag, Object, Size);
  }
 
  return Result;
}
 
int SLUpdate(SLLIST *Item,
             int NewTag,
             void *NewObject,
             size_t NewSize)
{
  int Result = SL_SUCCESS;
 
  void *p;
  
  if(NewSize > 0)
  {
    p = realloc(Item->Object, NewSize);
    if(NULL != p)
    {
      Item->Object = p;
      memmove(Item->Object, NewObject, NewSize);
      Item->Tag = NewTag;
      Item->Size = NewSize;
    }
    else
    {
      Result = SL_NO_MEM;
    }
  }
  else
  {
    Result = SL_ZERO_SIZE;
  }
 
  return Result;
}
 
void *SLGetData(SLLIST *Item,
                int *Tag,
                size_t *Size)
{
  void *p = NULL;
 
  if(Item != NULL)
  {
    if(Tag != NULL)
    {
      *Tag = Item->Tag;
    }
    if(Size != NULL)
    {
      *Size = Item->Size;
    }
    p = Item->Object;
  }
 
  return p;
}
 
SLLIST *SLDeleteThis(SLLIST *Item)
{
  SLLIST *NextNode = NULL;
 
  if(Item != NULL)
  {
    NextNode = Item->Next;
 
    if(Item->Object != NULL)
    {
      free(Item->Object);
    }
    free(Item);
  }
 
  return NextNode;
}
 
void SLDeleteNext(SLLIST *Item)
{
  if(Item != NULL && Item->Next != NULL)
  {
    Item->Next = SLDeleteThis(Item->Next);
  }
}
 
void SLDestroy(SLLIST **List)
{
  SLLIST *Next;
  if(*List != NULL)
  {
    Next = *List;
    do
    {
      Next = SLDeleteThis(Next);
    } while(Next != NULL);
    *List = NULL;
  }
}
 
int SLWalk(SLLIST *List,
           int(*Func)(int, void *, void *),
           void *Args)
{
  SLLIST *ThisItem;
  int Result = 0;
 
  for(ThisItem = List;
      0 == Result && ThisItem != NULL;
      ThisItem = ThisItem->Next)
  {
    Result = (*Func)(ThisItem->Tag,
                     ThisItem->Object,
                     Args);
  }
 
  return Result;
}
 
/* end of sllist.c */
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
// sllistmn.cpp
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
 
#include "sllist.h"
 
typedef struct BOOK
{
  char Title[30];
  char Author[30];
} BOOK;
 
typedef struct FIELD_INFO
{
  int TitleWidth;
  int AuthWidth;
} FIELD_INFO;
 
int PrintBook(int Tag, void *Memory, void *Args)
{
 // BOOK *b = Memory;
 // FIELD_INFO *f = Args;
 
  assert(Tag == 0);
 
 // printf("Read %*s, by %*s\n",
  //       f->TitleWidth,
  //       b->Title,
   //      f->AuthWidth,
   //      b->Author);
 
  return 0;
}
 
 
int main(void)
{
  BOOK Book[] =
  {
    {"Expert C Programming", "van der Linden"},
    {"C Programming FAQs", "Summit"},
    {"C++ Programming Language", "Stroustrup"},
    {"Algorithms in C", "Sedgewick"},
    {"Teach Yourself BCB", "Reisdorph"},
    {"The Standard C Library", "Plauger"},
    {"C++ Unleashed", "Liberty"},
    {"Data Structures & Algorithms", "Lafore"},
    {"C Programming Language", "Kernighan & Ritchie"},
    {"Linux Unleashed", "Husain and Parker"},
    {"C Unleashed", "Heathfield & Kirby"},
    {"C : A Reference Manual", "Harbison & Steele"},
    {"DOS Programmers Reference", "Dettmann & Johnson"},
    {"C: How to Program", "Deitel & Deitel"},
    {"Builder Unleashed", "Calvert"},
    {"UNIX Unleashed", "Burk and Horvath"}
 
  };
 
  SLLIST *List = NULL;
  SLLIST *Removed = NULL;
 
  BOOK *Data;
 
  FIELD_INFO FldInfo = { 30, 30};
  size_t NumBooks = sizeof Book / sizeof Book[0];
 
  size_t i;
 
  /* Populate the list */
  for(i = 0; i < NumBooks; i++)
  {
    if(SL_SUCCESS !=
          SLFront(&List, 0, Book + i, sizeof(BOOK)))
    {
      puts("Couldn't allocate enough memory.");
      SLDestroy(&List);
      exit(EXIT_FAILURE);
    }
  }
 
  /* Print the list */
  SLWalk(List, PrintBook, &FldInfo);
 
  /* Remove one item */
  Removed = List;
 
  for(i = 0; i < NumBooks / 2; i++)
  {
    Removed = Removed->Next;
  }
 
  SLGetData(Removed->Next, NULL, NULL);
  printf("\nRemoving title %s\n\n", Data->Title);
  SLDeleteNext(Removed);
 
  /* Print the list again to confirm deletion */
  SLWalk(List, PrintBook, &FldInfo);
 
  /* Destroy the list */
  SLDestroy(&List);
 
  return 0;
}
Visual Studio 2010

Код программы из книги Хэзфилд и Кирби "Искусство програмиирования на С"
Вложения
Тип файла: zip saod.zip (2.60 Мб, 11 просмотров)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 02:40. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru