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

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

Восстановить пароль Регистрация
 
Sabonar
3 / 3 / 0
Регистрация: 11.10.2012
Сообщений: 27
13.04.2013, 12:21     Поиск по структуре #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
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;
}
немного переделал и на одном из тестов он увеличил значение кол-ва названий в массиве до одного, однако само название не вывел.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.04.2013, 12:21     Поиск по структуре
Посмотрите здесь:

Структура. Поиск по структуре. C++
C++ Не работает поиск в структуре
Поиск одинаковых значений в структуре C++
C++ Поиск по структуре в бинарном файле
Организовать поиск в структуре C++
Поиск сотрудника по структуре C++
Сортировка и поиск данных в структуре C++
Поиск в структуре C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 09:26. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru