мне нужно отсортировать массив записей,содержащих наименования алфавитном порядке.
как это сделать в с++ я понятия не имею.
подскажите,пожалуйста,как это сделать.
буду благодарна за помощь.
С:
используем qsort
C++:
используем std::vector.sort
а если подробно описывать.
в смысле без стандартных вот этих функций:?
и кстати как можно в тексте программы сравнить символьную величину с конкретным словом?
#include <string.h>
#define n 10
typedef struct tagT {
char title[20];
double price;
} T;
int main() {
int i, j;
T arr[10] = {
{"1234", 10.0},
{"a234", 10.0},
{"u234", 10.0},
{"f234", 10.0},
{"m234", 10.0},
{"gg34", 10.0},
{"er34", 10.0},
{"op34", 10.0},
{"ni34", 10.0},
{"ab34", 10.0}
};
T buffer;
printf("before:\n");
for(i = 0; i < 10; ++i)
printf("%10s (%f)\n", arr[i].title, arr[i].price);
for(i = 0; i < n; ++i)
for(j = n - 1; j >= i; --j) {
if(strcmp(arr[j - 1].title, arr[j].title) > 0) {
memmove(&buffer, &arr[j - 1], sizeof(T));
memmove(&arr[j - 1], &arr[j], sizeof(T));
memmove(&arr[j], &buffer, sizeof(T));
}
}
printf("after:\n");
for(i = 0; i < 10; ++i)
printf("%10s (%f)\n", arr[i].title, arr[i].price);
return 0;
}
вот то,что у меня получилось.
компилируется,но выдает ошибку приложения.
не подскажете,в чем может быть проблема?
#include <iostream.h>
#include <fstream.h>
#include <string.h>
int main()
{
ofstream fout("output.txt");
typedef struct tagT
{
char descr_goods [20]; //наименование товара
char name_shop [20]; //название магазина
int good_value; //стоимость товара
} T;
int n=3; //кол-во записей
T list [n];
//вводим данные
cout << "name goods - name shop - good value" << endl;
for (int i=0;i<n;i++)
{
cout << "Memo " <<i+1 << endl;
cin >> list[i].descr_goods;
cin >> list[i].name_shop;
cin >> list[i].good_value;
fout << list[i].descr_goods << " - " << list[i].name_shop << " - " << list[i].good_value << "rub" << endl;
};
//сортируем по названиям магазинов
T buf;
for (int i=0;i<n;i++)
for (int j=n-1;j>=i;j--)
{
if (strcmp(list[j-1].name_shop,list[j].name_shop)>0)
{
memmove (&buf, &list[j-1], sizeof(T));
memmove (&list[j-1],&list[j], sizeof(T));
memmove (&list[j], &buf, sizeof(T));
};
};
//запрос на ассортимент в магазине
char rep [3];
char name [20];
cout << "Vivesti info o tovarax magazinov?";cin >> rep;
if (strcmp(rep,"yes")==0)
{
cout << "Vvedite nazvanie magazina:";cin >> name;
int k=0;
for (int i=0;i<n;i++)
if (strcmp(list[i].name_shop,name)==0)
{
cout << list[i].descr_goods << " - " <<list[i].good_value<< "rub" << endl;
k++;
};
if (k==0) cout << "Takogo magazina v baze net=(";
}
else cout << "Ok!V sleduyuschiy raz=)";
//записываем в файл изменения
for (int i=0;i<n;i++)
{
fout << list[i].descr_goods << " - " << list[i].name_shop << " - " << list[i].good_value << "rub" << endl;
};
}
Хм... Выход за нижнюю границу массива. Странно, Турбо С не ловит это. Поймал на MinGW... Исправь:
//сортируем по названиям магазинов
T buf;
for (int i=0;i<n;i++)
for (int j=n-1;j>=i+1;j--) // <--- Добавлено +1
//сортируем по названиям магазинов
T buf;
for (int i=0;i<n;i++)
for (int j=n-1;j>i;j--)