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

Сортировка структуры - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Найти произведение всех целых чисел в диапазоне от А до Б включительно http://www.cyberforum.ru/cpp-beginners/thread120590.html
Помогите кто-нибудь пожалуйста я полный ноль в программировании... Нужно написать две простенькие програмки на С++. 1) Вводятся с клавиатуры координаты диагонали прямоугольника (типа "1 3 4 9")....
C++ Консольное приложение начисления отпускных. Здравствуйте, пишу первый раз на данном форуме. Ищу помощь,в виде кода и коментариев к этой задачи. Программное обеспечение для начисления отпускных. Указание: При расчете суммы отпускных берутся... http://www.cyberforum.ru/cpp-beginners/thread120567.html
Связный список C++
Посчитать сколько слов, содержит текст поисзвольной длины. Разделителем между словами является символ пробела. Вывести на экран список всех встречающихся в тексте слов и их количество. Указание:...
C++ Структура
Информация о хранящихся на складе товарах состоит из: 1) инвентаризационного номера; 2) наименование товара; 3) количество в штуках; 4) цены; 5) даты поставки. Напишите структуру, описывающую...
C++ двойной указателем на указатель на вектор (C++) http://www.cyberforum.ru/cpp-beginners/thread120544.html
Доброго времени суток. Столкнулся со следующей проблемой Код: //файл matrix.h #include <iostream> #include <cstdlib> #include <vector> #include <fstream>
C++ Переписать первые элементы каждой строки матрицы D(3,3), которые больше 10, в массив В. Пожалуйста помогите написать прогу на C Переписать первые элементы каждой строки матрицы D(3,3), которые больше 10, в массив В. подробнее

Показать сообщение отдельно
spam_by
0 / 0 / 0
Регистрация: 19.04.2010
Сообщений: 1

Сортировка структуры - C++

22.04.2010, 20:06. Просмотров 610. Ответов 0
Метки (Все метки)

Такая задача уже неоднократно была описана на вашем форуме но сортировки негде несмог найти:
Написать функцию, которая читает данные о ноутбуках из файла note.txt (см. Задача 40) в структуру приведенного вида. Написать функцию, которая записывает содержимое структуры в конец бинарного файла. Структура бинарного файла: первые два байта (целое) число записей в файле; далее записи в формате структуры NOTEBOOK.
Написать программу, в которой на основе разработанных функций осуществляется чтение данных только для тех ноутбуков, частота процессора которых больше 120 МГц, и запись в бинарный файл по убыванию цены.
Вот что навоял(точнее собрал из готовых алгоритмов)
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
#include <fstream.h>
#include <conio.h>
#include <string.h>
#include <iostream.h>
#include <fstream.h>
#include <iomanip.h>
#include <stdlib.h>
#include <stdio.h>
 
struct NOTEBOOK {
    char model[21];     
    struct size {       
    float x;
    float y;
    float z;
    };
    size xyz;
    float w;    
    int price;
    int Hz;
};
 
istream& operator>>(istream &in, NOTEBOOK &note)
{
    memset(&note, 0, sizeof(note));
    char buffer[100];
    in.getline(buffer, sizeof(buffer));
 
    sscanf(buffer,
 "%20c %u %f %fx%fx%f %u",
 &note.model,
 &note.price,
 &note.w,
 &note.xyz.x,
 &note.xyz.y,
 &note.xyz.z,
 &note.Hz
 );
    return in;
}
 
ostream& operator<<(ostream &out, const NOTEBOOK &note)
{
 
cout << note.model 
<< note.price << ' '
      << note.w  << ' ' << note.xyz.x  << ' '
      << note.xyz.y  << ' '
      << note.xyz.z  << endl;
 
   return out;
}
 
istream& read(istream &in, NOTEBOOK &note)
{
   return in.read((char*)&note, sizeof(note));
}
 
 
iostream& write(iostream &io, const NOTEBOOK &note) 
{
   union 
   {
       unsigned value;
       char     buf[2];
   } size = {1};
 
   io.seekg(0, ios::beg);
   io.read(size.buf, sizeof(size.buf));
   io.clear();
   ++size.value;
   io.seekp(0, ios::beg);
   io.write(size.buf, sizeof(size.buf));
   io.seekp(0, ios::end);
   io.write((const char*)&note, sizeof(note));
   return io;
}
 
void main()
{
    
   NOTEBOOK note;
   ifstream in("note.txt");
   fstream bin("note.bin", ios::in|ios::out|ios::binary);
 
   while (in >> note)
   {
       write(bin, note);
       if (in.eof()) break;//!!!
   }
 
   bin.seekg(2, ios::beg);
 
   while (read(bin, note))
   {
       if (bin.eof()) break;//!!!
       cout << note;
   }
 
   getch();
}
Прошу помощи у знающих людей!!! Принцип сортировки структур мне известен но вот как приминить его к данному коду я хз((
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.