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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Compare - не понимаю смысла http://www.cyberforum.ru/cpp-beginners/thread688350.html
Не понимаю смысла функции COMPARE в решении данной задачи. (16 строчка) Сортируем по убыванию, все просто. Почему возвращаемое значение этой функции - разность величин? Что вообще должна возвращать функция COMPARE? Разве в нашем случае не наименьшее из двух величин? if (a<b) return a; else return b; Объясните, пожалуйста. Условие: Написать программу, которая находит «башню» из атлетов...
C++ Нарисовать окружность Пишу на Visual C++ 2012. вот коды: // Win32Project1.cpp: определяет точку входа для приложения. // #include "stdafx.h" #include "Win32Project1.h" #include "laba2.h" http://www.cyberforum.ru/cpp-beginners/thread688349.html
C++ почему то первый в этом коде у меня не нулевой элемент а идет по порядку все
#include "stdafx.h" #include <iostream> #include "conio.h" #include "locale.h" #define countof(array) (sizeof(array) / sizeof((array))) using namespace std; int main(void)
Строки: Дано предложение. Удалить из него все буквы «с» C++
Дано предложение. Удалить из него все буквы «с».
C++ Работа с файлом http://www.cyberforum.ru/cpp-beginners/thread688335.html
#include <stdio.h> #include <conio.h> int main(void){ FILE *fid; char ch, p; int i=1; if ((fid = fopen("D:\\data1.txt", "w")) == NULL)
C++ Ввод массива в Memo #include <stdio.h> void __fastcall TForm1::Button1Click(TObject *Sender) { int a={3, -1, 15, -7, 9, 3, 0}; int i,maxOtr; for (i=0; i<=6; i++) maxOtr=a; for (i=1; i<=6; i++) if (a>maxOtr && a>0) maxOtr=a; подробнее

Показать сообщение отдельно
byi_ja
7 / 7 / 0
Регистрация: 16.05.2012
Сообщений: 31
04.11.2012, 16:40     Сортировка массива структур
не могу понять почему не работает. Программа должна сортануть массив из 10 елементов типа Struct.
массив я забиваю из файла.

есть код:
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
#include <conio.h>
#include <iostream>
#include <fstream>
 
using namespace std;
 
struct modyl
{
    char Sprizv[20];
    char Sinic[2];
    int Irate;
};
 
void perestanovka(modyl *a)
{
    modyl c;
    for(int j=0;j<10;j++)
    for(int i=10-1;i>j;i--)
    if(a[i].Sinic< a[i-1].Sinic)            //вот тут
        {
        c=a[i];
        a[i]=a[i-1];
        a[i-1]=c;
        }
 
    for(int i=0;i<10;i++)   
    {
        cout<<a[i].Sprizv<<' '<<a[i].Sinic<<' '<<a[i].Irate<<endl;      
    }
}
хотя такой код будет даже очень работать:
C++
1
if (a[1].Sinic>a[2].Sinic) cout<<a[1].Sinic;else cout<<a[2].Sinic;
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 10:27. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru