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

Не могу организовать поиск в структуре - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Проверка! http://www.cyberforum.ru/cpp-beginners/thread95596.html
Вот код программы #include "stdafx.h" #include <iostream> #include <stdio.h> #include <conio.h> #include <limits> using namespace std; int _tmain(int argc, _TCHAR* argv) { int L(0),C(0), bad_input; //размеры матриц
C++ Функции Помогите пожалуйста решить... Дата некоторого дня характеризуется тремя натуральными числами: g (год), m (порядковый номер месяца) и n(число). По заданным g,n и m опередить: а)дату предыдущего дня; б)дату следующего дня; Определить функцию, определяющую количество дней в том или ином месяце. Кто знает скажите пожалуйста как решается это. http://www.cyberforum.ru/cpp-beginners/thread95593.html
массив C++
народ помогите плиз с написанием проги Дан двумерный массив С, каждый элемент разделить на произведение элементов всего столбца.
C++ Защита ввода.
Как защитить размер матрицы от набора букв или символов?
C++ среднее арифметическое двух чисел. http://www.cyberforum.ru/cpp-beginners/thread95549.html
всем привет с праздником . помогите пожалуйста .как правельно написать программу, вычисляющую среднее арифметическое двух чисел. в этой програме мне нужно записать Microsoft Visual Studio 2008
C++ Распознавание изображений Уважаемые подскажите с сл.вопросом: Так получилось что я раздолбай прогулял весь курс по С++, но теперь нужно через месяца 2-3 сдать сл. работу: Должна быть такая программа(что-то типо баузера) в ней должна быть адресная строка - нужно набрать адрес сайта учебного(но через инет), отрывается сайт, там будет табличка(случайна) с нее нужно будет прочесть число(которые скрывается за всякими... подробнее

Показать сообщение отдельно
Bald
0 / 0 / 0
Регистрация: 10.02.2010
Сообщений: 7
14.02.2010, 17:58     Не могу организовать поиск в структуре
Люди помогите с програмой.
Условие: для заданого варинта структуры написать следующее функции:
- формирование одномерного массива структур, реализовать механизм ввода заранее заданого количества структур;
- запись в файл массива структур;
- дополнение уже существующего файла новыми струтурами;
- вывод на экран содержимого файла;
- поиск информации по запросу;
Вроде все работает, а поиск не как организовать не могу, помогите.
И так если кто какие ошибки заметит исправьте плиз.
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
#include <iostream>
#include <stdio.h>
#include <iomanip>
#include <conio.h>
 
 
using namespace std;
 
struct vladelec{
    char name[20];
    char nomer_auto[10];
    char data[15];
    char telefon[20];
    char nomer_texpasporta[20];
};
 
void Inputvladelca(vladelec& el);
void Outputvladeleca(vladelec il);
int SizeFile(vladelec x);
void FindQuery();
int FindMenu();
int MainMenu();
void GreateDataBase();
 
int main()
{
    FILE *DataBase;
 
    int n;
    vladelec b, *a;
    bool run = true;
 
while(run)
switch (MainMenu())
{
case 0: run = false; break;
case 1:
    {
        clrscr();
    cout << "Vvedite kolichestvo zapisey " << endl;
    cin >> n;
    a = new vladelec[n];
    if ((DataBase = fopen("Base.db", "wb+")) == 0)
        cout << "Error: 1";
    for(int i = 0; i < n; i++)
    {
        cout << "Zapis nomer " << i+1 << ":" << endl;
        Inputvladelca(a[i]);
        fwrite(&a[i], sizeof a[i], 1, DataBase);
    }
    fclose(DataBase);
    }
    break;
 
case 2:
    {
        clrscr();
    if ((DataBase = fopen("Base.db", "ab+")) == 0)
        cout << "Error: 2";
    cout << "Dobavit zapis" << endl;
    Inputvladelca(b);
    fwrite(&b, sizeof b, 1, DataBase);
    fclose(DataBase);
    }
    break;
 
 
 
case 3:
    {
        clrscr();
    int i = 1;
    if ((DataBase = fopen("Base.db", "rb+")) == 0)
        cout << "Error: 3";
 
    while(fread(&b, sizeof b, 1, DataBase))
    {
        Outputvladeleca(b);
        i++;
    }
    fclose(DataBase);
        getch();
    }
    break;
case 4:
        {
        FindMenu();
        }
}
    return 0;
}
 
void Outputvladeleca(vladelec il)
{
    cout << "Imja  " << il.name<<endl;
        cout << "Nomer avto  " << il.nomer_auto<<endl;
        cout << "Data rozdenia  "<< il.data<<endl;
    cout << "Telefon  " << il.telefon<<endl;
        cout << "Nomer techpasporta  " << il.nomer_texpasporta<<endl;
 
}
 
void Inputvladelca(vladelec& el)
{
    cout << "Imja: ";
    cin >> el.name;
    cout << "Nomer avto: ";
    cin >> el.nomer_auto;
    cout << "Data rozdenija: ";
    cin >> el.data;
    cout << "Telefon: ";
    cin >> el.telefon;
    cout << "Nomer Techpasporta: ";
    cin >> el.nomer_texpasporta;
 
}
 
int SizeFile(vladelec x)
{
    FILE *f;
    int i = 0;
    if ((f = fopen("Base.db", "rb+")) == 0)
        cout << "Error: 3";
    while(fread(&x, sizeof x, 1, f)) i++;
    fclose(f);
        return i;
}
 
void FindQuery(name)
{
FILE *f;
fseek (f, name*sizeof(struct vladelec),SEEK_SET);
}
 
int FindMenu()
{
 
    cout << " [1] Poisk po Imeni" << endl;
    cout << " [2] Poisk po nomeru auto" << endl;
    cout << " [3] Poisk po date rozhdeniya" << endl;
    cout << " [4] Poisk po telefonu" << endl;
    cout << " [5] Poisk po nomeru texpasporta" << endl;
 
 
    int em;
    cin >> em;
    return em;
}
 
int MainMenu()
{       clrscr();
    cout << "=====[ Main Menu ]=====" << endl;
    cout << " [1] Create File" << endl;
    cout << " [2] Add Data" << endl;
    cout << " [3] Print File" << endl;
    cout << " [4] Find for File" << endl;
    cout << " [0] EXIT" << endl;
    cout << "=======================" << endl;
    int em;
    cin >> em;
    return em;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 14:15. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru