Дан массив студентов ВУЗа: ФИО, возраст, регион, факультет. Вывести на экран результирующую таблицу: регион, количество студентов из этого региона

"Дан массив студентов некоторого ВУЗа: ФИО, возраст, регион, факультет. Вывести на экран результирующую таблицу: регион, количество студентов из этого региона. Отсортировать данные по названию региона." Собственно, не могу разработать алгоритм подсчёта этих студентов.
#include <iostream>
#include <string.h>
using namespace std;
struct Student
{
    char fio[20];
    char region[20];
    char fac[20];
    int year;
};
struct Stado
{
    char region[20];
    int kol;
};
void Input(int n, Student mas1[])
{
    for (int i=0; i<n; i++)
    {
        cout<<"Введите инициалы, регион, факультет и год: ";
        cin>>mas1[i].fio>>mas1[i].region>>mas1[i].fac>>mas1[i].year;
        //cin.get();
    }
}
void main()
{
    setlocale(LC_ALL,"Russian");
    const int N=3;
    Student hell[N];
    Input(N,hell);
    Stado masa[N];
    Stado first[N];
    int koll;
    for(int i=0; i<N; i++)
    {
        strcpy(masa[i].region,hell[i].region);
        masa[i].kol=0;
 
        for(int j=i; j<N; j++)
        {
            if (strcmp(masa[j].region,masa[j++].region)==0)
                masa[j].kol += 1;
        }
    }
    cout<<"Количество студентов"<<endl;
    for(int i=0; i<N; i++)
    {
        cout<<masa[i].region<<"  "<<masa[i].kol<<endl;
    }
    cout<<first[N].region<<' '<<first[N].kol;
    cin.get();
    cin.get();
}
Что-то тут пришло в голову, но пока объявлял структуры и функцию ввода, забыл, что я хотел сделать. В итоге, на выходе получил какую-то ерунду...
#include <iostream>
#include <string.h>
using namespace std;
struct BIO
{
    char FIO[15];
    int year;
    char region[15];
    char fac[15];
};
struct Student
{
    char region [15];
    int kol;
};
//Ввод
void Input (int n, BIO arr[])
{
    for (int i=0; i<n; i++)
    {
        cout<<"Print FIO, year, region, fac: ";
        cin>>arr[i].FIO>>arr[i].year>>arr[i].region>>arr[i].fac;
        cin.get();
    }
}
//Выполнение первого задания
void Output (int n, BIO arr[]) 
{
    for (int i=0; i<n; i++)
    {
        cout<<arr[i].FIO<<": "<<arr[i].year<<", "<<arr[i].region<<", "<<arr[i].fac<<endl;
    }
    cin.get();
}   
void main()
{
    const int N=3;
    char tmp[15];
    BIO BIOArr[N];
    Student StudArr[N]; 
    Input(N, BIOArr);
    Output(N, BIOArr);
    for (int i=0; i<N; i++)
    {
        strcpy(StudArr[i].region,BIOArr[i].region);
        StudArr[i].kol=1;
    }
    for (int i=0; i<N-1; i++)
    {
        for (int j=0; j<N-1; j++)
        {
            if (strcmp(StudArr[j+1].region,StudArr[j].region)<0)
            {
                strcpy(tmp,StudArr[j+1].region);
                strcpy(StudArr[j+1].region,StudArr[j].region);
                strcpy(StudArr[j].region,tmp);
            }
            if (strcmp(StudArr[j+1].region,StudArr[j].region)==0) 
                StudArr[j].kol+=1;
        }
    }
    cout<<"Kol Student: "<<endl;
    for (int i=0; i<N; i++)
        cout<<StudArr[i].region<<" = "<<StudArr[i].kol<<endl;
    cin.get();
}
И всё равно. Не знаю, как вычёркивать уже подсчитанный регион
2 ответа

#include <iostream>
#include <string.h>
using namespace std;
struct BIO
{
    char FIO[15];
    int year;
    char region[15];
    char fac[15];
};
struct Student
{
    char region [15];
    int kol;
};
//Ввод
void Input (int n, BIO arr[])
{
    for (int i=0; i<n; i++)
    {
        cout<<"Print FIO, year, region, fac: ";
        cin>>arr[i].FIO>>arr[i].year>>arr[i].region>>arr[i].fac;
        cin.get();
    }
}
//Выполнение первого задания
void Output (int n, BIO arr[]) 
{
    for (int i=0; i<n; i++)
    {
        cout<<arr[i].FIO<<": "<<arr[i].year<<", "<<arr[i].region<<", "<<arr[i].fac<<endl;
    }
    cin.get();
}   
void main()
{
    const int N=3;
    char tmp[15];
    BIO BIOArr[N];
    Student StudArr[N]; 
    Input(N, BIOArr);
    Output(N, BIOArr);
 
    int count=0;
    for (int i=0; i<N; i++)
    {
        bool f=true;
        for (int i1=0;i1<count;i1++)
        {
            if (!strcmp(StudArr[i1].region,BIOArr[i].region))
            {
                f=false;
                StudArr[i1].kol++;
            }
        }
        if (f)
        {
            strcpy(StudArr[count].region,BIOArr[i].region);
            StudArr[count].kol=1;
            count++;
        }
    }
    cout<<"Kol Student: "<<endl;
    for (int i=0; i<count; i++)
        cout<<StudArr[i].region<<" = "<<StudArr[i].kol<<endl;
 
    cin.get();
}


ViktorKozlov, Спасибо . О использовании логического типа я даже и не думал.