Предмет:
ИнформатикаАвтор:
skinnymayoСортировал массив пузырьком (сравнивал первый символ в названии магазина).
Пробегался циклом через массив и функцией strcmp, сравнивал названия магазинов и строку с названием того магазина, который мы ищем.
Если вкратце, strcmp возвращает нам -1 когда строка которая передаётся в качестве первого параметра больше, 0 когда они равны (по содержимому тоже), и 1 если строка которая передаётся 2 параметром больше.
Вот мой вариант:#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <windows.h>
template <typename T>
struct PRICE
{
char prod_name[20];
char shop_name[20];
T price;
};
template <typename T>
void sortByShop(PRICE<T>* arr, int size)
{
PRICE<T> tmp;
bool check=true;
while(check)
{
check=false;
for(int i=0; i < size-1; ++i)
{
if(toupper(arr[i].shop_name[0])>toupper(arr[i+1].shop_name[0]))
{
tmp = arr[i];
arr[i]=arr[i+1];
arr[i+1]=tmp;
check=true;
}
}
}
}
template <typename T>
void show(PRICE<T>* arr, int size)
{
for(int i = 0; i < size; ++i)
{
printf("shop name -> %s",arr[i].shop_name);
printf("poduct name -> %s",arr[i].prod_name);
printf("poduct price -> %d",arr[i].price);
}
}
int main()
{
const int size = 5;
PRICE<double> arr[size];
for(int i = 0; i < size; ++i)
{
printf("Enter shop name -> ");
scanf("%s",&arr[i].shop_name);
printf("Enter poduct name -> ");
scanf("%s",&arr[i].prod_name);
printf("Enter poduct price -> ");
scanf("%d",&arr[i].price);
}
show(arr,size);
sortByShop(arr,size);
printf("Sorted array.");
show(arr,size);
char target[20];
printf("Enter shop name -> ");
scanf("%s",&target);
bool check=false;
for(int i = 0; i < size; ++i)
{
if(strcmp(arr[i].shop_name,target)==0)
{
printf("Founded products:");
printf("poduct name -> %s",arr[i].prod_name);
check=true;
}
}
if(!check) printf("Shop is not founded.");
system("pause");
}
Автор:
ceceliaqxtbДобавить свой ответ
Предмет:
Русский языкАвтор:
gregory34Ответов:
Смотреть
Предмет:
Русский языкАвтор:
meganОтветов:
Смотреть
Предмет:
Английский языкАвтор:
emmyОтветов:
Смотреть
Предмет:
Окружающий мирАвтор:
kirbyzg1bОтветов:
Смотреть