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

Поиск по структуре - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Программа определяющая, пройдет ли график функции y = 5x2 – 7 x + 2 http://www.cyberforum.ru/cpp-beginners/thread836467.html
Ааа, народ выручайте пожалуйста. Сейчас экзамен в академии, а я не очень шарю в этом. Задание: 3. Составить программу, определяющую, пройдет ли график функции y = 5x2 – 7 x + 2 через заданную точку с координатами (a,b). Координаты – вещественные.
C++ Исключительные ситуации Создать базовый класс Exeption , и соответствующие классы наследники, позволяющие обрабатывать следующие исключительные ситуации: а. ошибки при работе с потоками ввода / вывода, в том числе при работе с файлами; б. ошибки арифметических операций (деление на 0); в. ошибки выделения динамической памяти при перегрузке операторов new и delete. Добавить класс в программу, и продемонстрировать... http://www.cyberforum.ru/cpp-beginners/thread836466.html
C++ Разработать классы и создать объекты
помогите пожалуйста.это срочно! 1.разработав класс окружность, создать три объекта изображающих движение: а)расширяющейся (сужающейся) окружности с неподвижным центром б)окружность постоянного радиуса, скользящий вдоль прямой в)окружности, осуществляющие два вышеописанных движения и имитирующее приближение (удаление) объекта в перспективе 2.1)с помощью механизма...
C++ Ошибка в Функции
#include <iostream.h> #include <stdlib.h> #include <conio.h> #include <iomanip.h> bubbleSort(int , const int); main() {
C++ Двумерные массивы. Постройте вектор, каждый элемент которого содержит наименьший за абсолютной величиной элемент строки http://www.cyberforum.ru/cpp-beginners/thread836448.html
Помогите создать прогу на С++ с заданным условием : Используя подпрограммы составить алгоритм и программу обработки двумерного массива: Пусть данна матрица А (n x n). Постройте вектор, каждый элемент которого содержит наименьший за абсолютной величиной элемент строки.
C++ Передача string массива Пытаюсь передать массив из C++ дллки в C# приложение. Сделал по http://msdn.microsoft.com/ru-ru/library/hk9wyw21.aspx При вызове функции говорит что Вызов функции PInvoke "WpfApplication2!WpfApplication2.MainWindow::TestArrayOfStrings" разбалансировал стек. Вероятно, это вызвано тем, что управляемая сигнатура PInvoke не совпадает с неуправляемой целевой сигнатурой. Убедитесь, что соглашение о... подробнее

Показать сообщение отдельно
Sabonar
3 / 3 / 0
Регистрация: 11.10.2012
Сообщений: 27

Поиск по структуре - C++

13.04.2013, 12:21. Просмотров 358. Ответов 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
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
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <limits.h>
 
//пропуск символов  до конца строки
#define CLR while (getchar()!='\n')
//максимальное число структур
#define Kmax 10
//максимальная длина строки
#define Lmax 81
//пропуск символов до конца строки  в файле
#define FCLR while (getc(fin)!='\n')
 
struct izdat
{char gorod[Lmax], iname[Lmax];
    int year;
};
 
struct bookset
  {
    char name[Lmax], author[Lmax];
  izdat iz;
  int price, page;
  };
void input (bookset *book, int *k) //ввод массива книг
  { int i;
 
  do
  {
    printf("enter number of books ");
    scanf("%d", k); //k – указатель на количество структур
  }
  while (*k<=0 || *k>Kmax);
  CLR; /* необходим пропуск символов  до конца строки, т.к. дальше функция gets - читается строка */
  for (i=0; i<*k; i++)
  {
     printf("BOOK # %d\n", i+1);
     printf("Name: "); gets(book[i].name);
     printf("Price: "); scanf("%d", &book[i].price);
     printf("Pages "); scanf("%d", &book[i].page);
     CLR;
     printf("Author: "); gets(book[i].author);
     printf("Publishing year: "); scanf("%d",&book[i].iz.year);
     CLR; //пропуск символа ‘\n’
     printf("City: "); gets(book[i].iz.gorod);
     printf("Publishing house: "); gets(book[i].iz.iname);
     printf("\n");
  }
  printf("Input is over\n");
  getchar();
}
 
 
void output (bookset* book, int k)
  {
  int i;
  printf("list of book sets: \n");
  for(i=0; i<k; i++)
     {
     printf("Book # %d\n", i+1);
     printf("Name: %s\n", book[i].name);
     printf("Price: %d\n", book[i].price);
     printf("Author: %s\n", book[i].author);
     printf("Book pages: %d\n", book[i].page);
     printf("City: %s\n", book[i].iz.gorod);
     printf("Publishing house: %s\n", book[i].iz.iname);
     printf("Publishing year: %d\n", book[i].iz.year);
     printf("Press any key to continue...\n");
     getchar();//ожидание нажатия клавиши
     }
  printf("End of list\n");
  printf("Press any key to continue...\n");
  }
 
 
void search (bookset *book, char books[][Lmax], int k, int *kg)
   {
    char iname1[20]="P";
   int min=0.5, i, j;
   for(i=0; i<k; i++) //
      if (strcmp(book[i].iz.iname,iname1)){
          if ((book[i].price/book[i].page)>min){
            for(j=0; j<*kg && strcmp(book[i].name, books[j]); j++);
                if (j==*kg)
                 strcpy(books[(*kg)++], book[i].name);
        }
    }
   }
 
int main()
{
bookset book[Kmax];
int k, kg=0, i;
char books[Kmax][Lmax];
input(book, &k);
output(book, k);
search(book,books,k,&kg);
printf("Result:\n%d books which have publishing house 'Prosvechenie' and low price for the page:\n",kg);
for (i=0;i<kg;i++)
    gets(books[i]);
return 0;
}
Добавлено через 19 минут
C++ (Qt)
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
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <limits.h>
 
//пропуск символов  до конца строки
#define CLR while (getchar()!='\n')
//максимальное число структур
#define Kmax 10
//максимальная длина строки
#define Lmax 81
//пропуск символов до конца строки  в файле
#define FCLR while (getc(fin)!='\n')
 
struct izdat
{char gorod[Lmax], iname[Lmax];
    int year;
};
 
struct bookset
  {
    char name[Lmax], author[Lmax];
  izdat iz;
  int price, page;
  };
void input (bookset *book, int *k) //ввод массива книг
  { int i;
 
  do
  {
    printf("enter number of books ");
    scanf("%d", k); //k – указатель на количество структур
  }
  while (*k<=0 || *k>Kmax);
  CLR; 
  for (i=0; i<*k; i++)
  {
     printf("BOOK # %d\n", i+1);
     printf("Name: "); gets(book[i].name);
     printf("Price: "); scanf("%d", &book[i].price);
     printf("Pages "); scanf("%d", &book[i].page);
     CLR;
     printf("Author: "); gets(book[i].author);
     printf("Publishing year: "); scanf("%d",&book[i].iz.year);
     CLR; //пропуск символа ‘\n’
     printf("City: "); gets(book[i].iz.gorod);
     printf("Publishing house: "); gets(book[i].iz.iname);
     printf("\n");
  }
  printf("Input is over\n");
  getchar();
}
 
 
void output (bookset* book, int k)
  {
  int i;
  printf("list of book sets: \n");
  for(i=0; i<k; i++)
     {
     printf("Book # %d\n", i+1);
     printf("Name: %s\n", book[i].name);
     printf("Price: %d\n", book[i].price);
     printf("Author: %s\n", book[i].author);
     printf("Book pages: %d\n", book[i].page);
     printf("City: %s\n", book[i].iz.gorod);
     printf("Publishing house: %s\n", book[i].iz.iname);
     printf("Publishing year: %d\n", book[i].iz.year);
     printf("Press any key to continue...\n");
     getchar();//ожидание нажатия клавиши
     }
  printf("End of list\n");
  printf("Press any key to continue...\n");
  }
 
 
void search (bookset *book, char books[][Lmax], int k, int *kg)
   {
    char iname1[20]="P";
   int min=0.5, i, j;
   for(i=0; i<k; i++) //
      if (!(strcmp(book[i].iz.iname,iname1))&&((book[i].price/book[i].page)>min)){
         for(j=0; j<*kg && strcmp(book[i].name, books[j]); j++);
             if (j==*kg)
             strcpy(books[(*kg)++], book[i].name);
        }
    }
 
int main()
{
bookset book[Kmax];
int k, kg=0, i;
char books[Kmax][Lmax];
input(book, &k);
output(book, k);
search(book,books,k,&kg);
printf("Result:\n%d books which have publishing house 'Prosvechenie' and low price for the page:\n",kg);
for (i=0;i<kg;i++)
    gets(books[i]);
return 0;
}
немного переделал и на одном из тестов он увеличил значение кол-ва названий в массиве до одного, однако само название не вывел.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 13:41. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru