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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ DES в режиме ECB http://www.cyberforum.ru/cpp-beginners/thread1186334.html
Вообщем такая проблема реализовал DES в режиме ECB,но что не хочет расшифровывать ,уже не знаю голову сломал,помогите найти ошибку а то уже курсовую сдавать а у меня нет //...
C++ Кратчайший цикл в графе (ориентированный, невзвешанный) Доброго времени суток! Имеется задача - нахождение кратчайшего цикла в ориентированном и невзвешанном цикле(ребра без значений). Граф задается путем массива очередей. Помогите решить сию задачу.... http://www.cyberforum.ru/cpp-beginners/thread1186330.html
С++ 4 и 5 поколение языков программирования C++
Является ли С++ языком 4 поколения? Пятое поколение Рождение языков пятого поколения произошло в середине 90-х годов. К ним отно*сятся также системы автоматического создания прикладных программ с...
Можно ли быть программистом многопрофильным? C++
Скажем, и системным, и прикладным. Или обязательно надо делать выбор? Или лучше углубиться в одной области, потому что нет шансов знать все на одном уровне? Спасибо.
C++ Линкер ругается на функцию http://www.cyberforum.ru/cpp-beginners/thread1186312.html
// laba7evteev.cpp: определяет можно ли из слов первой строки составить вторую // #include "stdafx.h" #include <string.h> int strToWords(char *str, char words); int markWords ( const char...
C++ При подключении заголовочного файла появляются ошибки переопределения функций Знаю, что эта тема размусолена, но попрошу немного добра. Пишу отдельный модуль с процедурами обработки двусвязного списка. При подключении заголовочного файла получаю ошибки 2005 о... подробнее

Показать сообщение отдельно
Tenzor
5 / 5 / 9
Регистрация: 21.05.2014
Сообщений: 29
24.05.2014, 02:26
Сначала считываем из файла всех игроков. Далее сортируем по убыванию баллов и выводим три первые фамилии в отсортированном массиве.

У меня получилось так:

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
#include <stdio.h>
#include <string.h>
#define N 4
using namespace std;
struct swed
{
    char    fio[31];
    int     bal;
};
 
int main()
{
    struct swed    d[N];
    FILE *         f;
    int            i, t, k;
    
    // Запись в файл
    if((f = fopen("D:\\f.txt", "wb")) != NULL)
    {
        for(i = 0; i < N; i++)
        {
            printf("prizv: ");
            // gets почему-то не срабатывал, заменил его на scanf
            scanf("%s",d[i].fio);
            //gets(d[i].fio);
            printf("bal: ");
            scanf("%d", &d[i].bal);
            puts("");
            fflush(stdin);
 
            fprintf(f,"%s \t",d[i].fio);
            fprintf(f,"%d \t",d[i].bal);
        }
        fclose(f);
    }
    
    // Чтение из файла
    if((f = fopen("D:\\f.txt", "rb")) != NULL)
    {   
        int d;
        swed result[N];
        // Таблица индексов, потребуется для сортировки результатов по убыванию
        int indixes[N];
        
        // Считываем данные из файла
        for(i=0; i<N; i++) {
            fscanf(f,"%s",result[i].fio);
            fscanf(f,"%d",&d);
            result[i].bal = d;
            indixes[i] = i;
        }
        
        // Сортируем по убыванию баллов
        for(int j=N-1; j>=0; j--) {
            for(int k=1; k<=j; k++) {
                if(result[k-1].bal<result[k].bal) {
                    // Чтобы не приравнивать строки
                    int temp = indixes[k];
                    indixes[k] = indixes[k-1];
                    indixes[k-1] = temp;
                    
                    int tempB = result[k].bal;
                    result[k].bal = result[k-1].bal;
                    result[k-1].bal = tempB;
                }
            }
        }
        
        // Выводим фамилии результативных игроков
        for(i=0; i<3; i++) {
            printf("%d. %s\n",(i+1),result[indixes[i]].fio);
        }
        fclose(f);
    }
    return 0;
}
1
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru