Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
1 / 1 / 0
Регистрация: 19.03.2012
Сообщений: 56

Отсортировать записи в порядке возрастания даты последнего платежа

18.12.2014, 14:26. Показов 1881. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дан файл P абонентов коммутатора за текущий год. Сведения:
1) абонентский номер
2) фамилия
3) адрес
4) сумма долга
5) дата последнего платежа
Задание:
а) вывести записи должников, у которых дата платежа меньше заданной;
б) отсортировать записи в порядке возрастания даты последнего платежа.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.12.2014, 14:26
Ответы с готовыми решениями:

Отсортировать (в порядке возрастания) записи по телефону
Цель работы: Задав массив записей, реализовать его обработку, как указано в варианте. В программе должны быть предусмотрены процедуры:...

Записи: Отсортировать массив в порядке возрастания среднего балла
Составить массив из 10 записей следующей структуры: 1)фамилия, имя, отчество – строки из 20 символов; 2)номер зачетки – строка из...

Отсортировать элементы строк матрицы в порядке возрастания, а строки - в порядке возрастания сумм элементов
Задать с клавиатуры количество целочисленных матриц. Данные получить с помощью датчика случайных чисел RANDOM. Отсортировать элементы...

1
CAPITAL OF ROCK!
 Аватар для JokeR.BY
1281 / 708 / 982
Регистрация: 03.03.2010
Сообщений: 2,286
18.12.2014, 15:53
Лучший ответ Сообщение было отмечено Vladimiir как решение

Решение

Pascal
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
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
type
    TMyDate = record
        d : 1..31;
        m : 1..12;
        y : Word;
    end;
    TAbon = record
        numb : String; //или что там за номер
        fam : String[20];
        adres : String[20];
        dolg : LongWord;
        lastPrice : TMyDate;
    end;
    TFile = File Of TAbon;
    TMass = Array[0..255] Of TAbon;
 
function CompDate(const a, b : TMyDate) : Boolean; //возвращает сравнение a > b
var
    Result : Boolean;
begin
    if (a.y > b.y)
    then
        Result := True
    else
        if (a.y < b.y)
        then
            Result := False
        else
            if (a.m > b.m)
            then
                Result := True
            else
                if (a.m < b.m)
                then
                    Result := False
                else
                    if (a.d > b.d)
                    then
                        Result := True
                    else
                        Result := False;
    CompDate := Result;
end;
 
procedure ShowMenu(); //просто вывод на экран менюшки
begin
    WriteLn;
    WriteLn('1. Add abon.');
    WriteLn('2. Search for.');
    WriteLn('3. Sort');
    WriteLn('4. Exit');
end;
 
procedure AddAbon(var f : TFile; const n : Byte); //добавление абонентов
var
    i : Byte;
    abon : TAbon;
begin
    Reset(f); Seek(f, FileSize(f));
    for i := 1 to n do
    begin
        with abon do
        begin
            {запрашиваем данные}
            WriteLn(i, ': ');
            Write('   Abon nomer: '); ReadLn(numb);
            Write('   Familia: '); ReadLn(fam);
            Write('   Adres: '); ReadLn(adres);
            Write('   Dolg: '); ReadLn(dolg);
            with lastPrice do
            begin
                {$R+}
                Write('   Platezh (dd mm yyyy): '); ReadLn(d, m, y);
                {$R-}
            end;
        end;
        Write(f, abon); //и записываем в файл
    end;
    Close(f);
end;
 
procedure PrintAbons(var f : TFile; const pr : TMyDate);
var
    abon : TAbon;
    i, k : Byte;
begin
    Reset(f); Seek(f, 0); k := 0;
    for i := 1 to FileSize(f) do
    begin
        Read(f, abon); //считываем
        with abon do
            if Not(CompDate(lastPrice, pr)) //сравниваем даты
            then
            begin
                {выводим}
                Inc(k);
                WriteLn(k, ':');
                WriteLn('   Abon nomer: ', numb);
                WriteLn('   Familia: ', fam);
                WriteLn('   Adres: ', adres);
                WriteLn('   Dolg: ', dolg);
                with lastPrice do
                    WriteLn('   Platezh: ', d, '.', m, '.', y);
            end;
    end;
    Close(f);
end;
 
procedure Swap(var a, b : TAbon); //процедура обмена двух переменных
var
    t : TAbon;
begin
    t := a;
    a := b;
    b := t;
end;
 
procedure SortFile(var f : TFile); //процедура сортировки и вывода сортированного файла
var
    ar : TMass;
    i, j, n : Byte;
begin
    Reset(f); Seek(f, 0);
    n := FileSize(f) - 1; //находим количество записей в файле
    for i := 0 to n do
        Read(f, ar[i]); //считываем в массив
    for i := 1 to n do
        for j := n downto i do
            if CompDate(ar[j - 1].lastPrice, ar[j].lastPrice) //сортируем пузырьковым методом
            then
                Swap(ar[j - 1], ar[j]);
    Close(f); ReWrite(f); //открываем на перезапись
    WriteLn('Sorted file: ');
    for i := 0 to n do
    begin
        Write(f, ar[i]); //выводим в файл
        with ar[i] do 
        begin
            {и на экран}
            WriteLn(i + 1, ':');
            WriteLn('   Abon nomer: ', numb);
            WriteLn('   Familia: ', fam);
            WriteLn('   Adres: ', adres);
            WriteLn('   Dolg: ', dolg);
            with lastPrice do
                WriteLn('   Platezh: ', d, '.', m, '.', y);
        end;
    end;
    Close(f);
end;
 
var
    f : TFile;
    k, t : Byte;
    date : TMyDate;
begin
    Assign(f, 'f.dat');
    repeat
        ShowMenu;
        ReadLn(k);
        case k of
            1:
            begin
                Write('n='); ReadLn(t);
                AddAbon(f, t);
            end;
            2:
            begin
                Write('dd mm yyyy: ');
                with date do
                    {$R+}
                    ReadLn(d, m, y);
                    {$R-}
                PrintAbons(f, date);
            end;
            3:
                SortFile(f);
            4:
                Exit;
            else
                WriteLn('ERROR!');
        end;
    until (false);
end.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.12.2014, 15:53
Помогаю со студенческими работами здесь

Функция: отсортировать в порядке убывания и в порядке возрастания сформированный вектор-столбец
Необходимо написать функцию по такому заданию: отсортировать в порядке убывания и в порядке возрастания сформированный вектор-столбец...

Первые десять элементов массива М(30) отсортировать в порядке возрастания, а остальные в порядке убывания
Привет. Первые десять элементов массива М(30) отсортировать в порядке возрастания, а остальные в порядке убывания. Вот тут я сделал массив...

Отсортировать четные строки матрицы Q(10х10) в порядке убывания, а нечетные – в порядке возрастания
Написать программу на си, задание: Отсортировать четные строки матрицы Q(10х10) в порядке убывания, а нечетные – в порядке возрастания....

Даты в порядке возрастания
Как ввести из МЕМО1(в котором введены даты) в поле МЕМО2 в порядке возрастания?

Рассортировать даты в порядке возрастания
Дан перечень дат (формат-&quot;21 сентября 1982г.&quot;). Рассортировать эти даты в порядке возрастания (данные -вводятся с клавиатуры ) ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru