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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Sabonar
3 / 3 / 0
Регистрация: 11.10.2012
Сообщений: 27
#1

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

13.04.2013, 12:21. Просмотров 369. Ответов 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;
}
немного переделал и на одном из тестов он увеличил значение кол-ва названий в массиве до одного, однако само название не вывел.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.04.2013, 12:21
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Поиск по структуре (C++):

Поиск в структуре - C++
Подскажите, пожалуйста, как сделать бинарный поиск в структуре?

Поиск по структуре - C++
Имеется функция поиска сотрудника по имени: void Searchname(video film, char *name) { int j=0; for (int i = 0; i&lt;col;...

Не работает поиск в структуре - C++
#include &lt;iostream&gt; #include &lt;string&gt; #include &lt;cstring&gt; #include &lt;windows.h&gt; #include &lt;limits&gt; using namespace std; ...

Организовать поиск в структуре - C++
Задача на тему : Структуры. Список сведений о животных в зоопарке. Каждая строка списка содержит наименование вида , пол, дату...

Структура. Поиск по структуре. - C++
Добрый вечер, ув. форумчане. Я новичек в С/C++, в данный момент сам учусь по урокам Шага. Дошел до структур, в принципе смысл понял, но...

Поиск сотрудника по структуре - C++
Вот работающая программка, она считает квартальную или годовую з/п выбранного по строке сотрудника. необходимо его выбирать по фамилии....

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
13.04.2013, 12:21
Привет! Вот еще темы с ответами:

Сделать поиск по структуре - C++
Создать список, в котором хранится информация о абонентов АТС: ФИО, место жительства, номер телефона. Необходимо написать программу,...

Сортировка и поиск данных в структуре - C++
Имеется структура данных: название института, номер корпуса, название кафедры и телефон кафедры. Требуется реализовать поиск по 3-м...

Не могу организовать поиск в структуре - C++
Люди помогите с програмой. Условие: для заданого варинта структуры написать следующее функции: - формирование одномерного массива...

Краш программы. Поиск по структуре - C++
Доброго времени суток, уважаемые форумчане! Я столкнулся с такой проблемой... Условие задачи : В записной книжке указаны фамилии и...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru