Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 19.04.2016
Сообщений: 42

Непонятки с сортировкой

15.11.2016, 16:12. Показов 994. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер.
Практически выполнил задание, но в конце возникла проблема с сортировкой, а именно, в задании нужно ввести название товара, магазина и цену.
После чего нужно вывести на экран информацию о товарах, продающихся в магазине, название которого введено с клавиатуры.
Здесь внимание:
Записи должны быть размещены в алфавитном порядке по названиям магазинов, при наличии 2-х одинаковых магазинов, они идут в точно таком же порядке, как и в исходном массиве, сортировка по названию товара или по цене отсутствует.
Пример входных данных:

Printer Yulmart 5820
Shkaf Ikea 3530
Kholodilnik Zakazhi 31999
Kastryulya Perekrestok 920
Skovoroda Zakazhi 1770
Televizor Sitilink 22700
Noutbuk Yulmart 19995
Divan Metrika 13980
Metrika

Пример выходных данных:

Shkaf Ikea 3530
Divan Metrika 13980
Kastryulya Perekrestok 920
Televizor Sitilink 22700
Printer Yulmart 5820
Noutbuk Yulmart 19995

Kholodilnik Zakazhi 31999
Skovoroda Zakazhi 1770
Divan 13980

А вот мой вывод:
Shkaf Ikea 3530
Divan Metrika 13980
Kastryulya Perekrestok 920
Televizor Sitilink 22700
Noutbuk Yulmart 19995
Printer Yulmart 5820

Kholodilnik Zakazhi 31999
Skovoroda Zakazhi 1770
Divan 13980

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
#include <iostream>
#include <string>
using namespace std;
 
const int N = 8;
 
struct PRICE {
    char name[15];
    char shop[15];
    char nshop[15];
    int price;
    bool g;
 
};
 
void sortirovka(PRICE *struk, const int N);
 
int main()
{
 
    PRICE struk[N + 1];
 
    for (int i = 0; i <= 7; i++) {
        cin >> struk[i].name;
        cin >> struk[i].shop;
        cin >> struk[i].price;
    }
 
 
    sortirovka(struk, N);
 
    bool g = false;
    char nshop[15];
    cin >> nshop;
 
    for (int i = 0; i < N; i++)
    {
        cout << struk[i].name << " ";
        cout << struk[i].shop << " ";
        cout << struk[i].price << endl;
 
    }
 
    for (int i = 0; i < N; i++)
        if (strstr(nshop, struk[i].shop)) {
            g = true;
            cout << struk[i].name << " " << struk[i].price;
        }
 
 
    if (!g) {
        cout << "No";
    }
 
    return 0;
}
 
void sortirovka(PRICE *struk, const int N)
{
    PRICE tmp;
    for (int t = 0; t < N; t++)
        for (int i = 0; i < N; i++) {
            if (struk[i].shop[0] > struk[t].shop[0])
            {
                tmp = struk[i];
                struk[i] = struk[t];
                struk[t] = tmp;
            }
        }
}
Как видите, Printer Yulmart был введен раньше, но выводится после Noutbuk Yulmart 19995, который был введен после.
Помогите пожалуйста! Не понимаю как это исправить
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
15.11.2016, 16:12
Ответы с готовыми решениями:

Непонятки с сортировкой данных в структуре (Осторожно, увиденного не развидеть.)
Доброго времени суток каждому из вас. Попытался осуществить сортировку данных в структуре, посредством ужасных конструкций и нагромождений...

Отсортировать одномерный массив, заполненный случайными числами, сортировкой Шелла и сортировкой выбором
Отсортировать одномерный массив, заполненный случайными числами, сортировкой Шелла и сортировкой выбором.

Сортировать массив символов обменной, карманной сортировкой, сортировкой вставками
Сортировать массив символов обменной, карманной сортировкой, сортировкой вставками . Оценить реальное время на сортировку каждым из методов...

4
93 / 69 / 22
Регистрация: 17.10.2011
Сообщений: 235
15.11.2016, 16:57
попробуй
C++
1
62:... for (int i = t+1; ...
0
0 / 0 / 0
Регистрация: 19.04.2016
Сообщений: 42
15.11.2016, 17:16  [ТС]
Цитата Сообщение от vndtta Посмотреть сообщение
попробуй
1
62:... for (int i = t+1; ...
Попробовал, неправильно
Вот что выводит в вашем варианте:
Kholodilnik Zakazhi 31999
Skovoroda Zakazhi 1770
Printer Yulmart 5820
Noutbuk Yulmart 19995
Televizor Sitilink 22700
Kastryulya Perekrestok 920
Divan Metrika 13980
Shkaf Ikea 3530
Divan 13980

Добавлено через 11 минут
Вообще я думал, что это автоматически должно происходить, странно как-то
0
 Аватар для lawr
385 / 279 / 478
Регистрация: 09.05.2014
Сообщений: 769
15.11.2016, 17:23
Лучший ответ Сообщение было отмечено Дриддерс как решение

Решение

потому, что во время очередного прохода запись принтера из юлмарта меняется с записью дивана из метрики, которая находится ПОСЛЕ записи юлмартовского ноутбука. вывод- сортировка выбором в даном случае не катит. сортировка пузырьком по идее должна дать нужный результат. не все сортировки одинаково полезны
1
0 / 0 / 0
Регистрация: 19.04.2016
Сообщений: 42
15.11.2016, 20:19  [ТС]
Столько времени потратил на то, чтобы понять как это исправить, сделал как вы сказали, сортировкой пузырьком, все заработало -_-
Спасибо большое!)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.11.2016, 20:19
Помогаю со студенческими работами здесь

Сортировать числовой файл обменной сортировкой, сортировкой вставками
Уааа, ребят помогите пожалуйста, уже просто мозги кипят не знаю что делать. Задание: Сортировать числовой файл(целые числа) обменной...

Не понятно с сортировкой!
Добрый вечер! Возникла неясность с пузырьковой сортировкой. В чём загвоздка? В задании надо присвоить в структуру оператор &lt;, чтобы...

Проблемы с сортировкой
Доброго времени Имеется база данных access со следующими полями: Дата Наименование Стоимость Количество Примечание

Задача с сортировкой
Доброго, знатоки! Как будет выглядеть код такой задачи и сложно ли это для не очень подготовленного пользователя? Дано: Строка1 =...

Проблемы с сортировкой.....
Я с помощью DAO добавляю данные в таблице 'Списки'. Как мне эти данные потом отсортировать по количеству профессий(Количество...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru