Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
13 / 13 / 6
Регистрация: 27.05.2012
Сообщений: 208

Найти максимальную разность между соседними членами последовательности

29.01.2016, 12:20. Показов 2428. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, есть запрос, который работает правильно(по моему мнению). Тут мне говорят, что в коде есть ошибка.
Помогите найти ошибку, потому что я её не наблюдаю.

Найти максимальную разность между соседними членами последовательности. Нахожу макс.разность в поле "Цена" таблицы "Заказы".
SQL
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
DROP PROCEDURE максразность
GO
CREATE PROCEDURE максразность
AS
    DECLARE @razn INT, @numf INT, @nums INT, @pricef INT, @prices INT
    SET @razn=-1000
    SET @numf=0
    SET @nums=0
        
    SELECT @nums=MIN([код заказа])
        FROM Заказы
        WHERE [код заказа]>@nums
        
        SET @numf=@nums
    WHILE (@nums IS NOT NULL)
    BEGIN
        SELECT @pricef=Цена
            FROM Заказы
            WHERE [код заказа]=@numf
 
        SELECT @prices=Цена
            FROM Заказы
            WHERE [код заказа]=@nums
        IF (@pricef-@prices)>@razn
            SET @razn=@pricef-@prices        
 
          SET @numf=@nums
      SELECT @nums=MIN([код заказа])
        FROM Заказы
        WHERE [код заказа]>@numf
    END
    RETURN @razn
GO
 
SELECT [код заказа], Цена
FROM Заказы
ORDER BY [код заказа]
DECLARE @razn INT
EXEC @razn=максразность
SELECT 'Максимальная разность' = @razn
GO
P.S. говорят, не нужно получать повторно @pricef в цикле.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.01.2016, 12:20
Ответы с готовыми решениями:

Для вводимой последовательности целых чисел найти максимальную разность между соседними элементами
1-ая задача: Для вводимой последовательности целых чисел найти максимальную разность между соседними элементами последовательности,...

Определить максимальную разность между двумя соседними цифрами числа
Написать программу для с++: Дано целое число N. Определить максимальную разность между двумя соседними цифрами.

Заполнить массив случайными числами, посчитать максимальную разность между 2 соседними величинами
очень нужно,завтра модуль закрывать,а это решающее задание,кину на счет денег или как-то по-другому,в общем в обиде не оставлю!!! ...

5
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
29.01.2016, 12:54
Цитата Сообщение от Lers Посмотреть сообщение
говорят, не нужно получать повторно @pricef в цикле.
Правильно говорят.

Да и цикл вообще не нужен. Задача без него решается.
А если уж цикл, то через курсор.
0
13 / 13 / 6
Регистрация: 27.05.2012
Сообщений: 208
29.01.2016, 16:24  [ТС]
Цитата Сообщение от Lers Посмотреть сообщение
SELECT @pricef=Цена
* * * * * * FROM Заказы
* * * * * * WHERE [код заказа]=@numf
Если убрать, то выдает не правильный результат, да нужно конкретно использовать цикл, без курсора.
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
29.01.2016, 16:49
Лучший ответ Сообщение было отмечено Lers как решение

Решение

Цитата Сообщение от Lers Посмотреть сообщение
Если убрать, то выдает не правильный результат
Конечно не правильный. Потому что убрать мало, нужно еще добавить к SET @numf=@nums @pricef = @prices
Цитата Сообщение от Lers Посмотреть сообщение
да нужно конкретно использовать цикл, без курсора.
Нужно для чего? Запутать код и нагрузить сервер ненужной работой?
1
13 / 13 / 6
Регистрация: 27.05.2012
Сообщений: 208
29.01.2016, 17:17  [ТС]
Сейчас попробую. Требуют так, в образовательных целях))

Добавлено через 10 минут
Да работает, спасибо.
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
29.01.2016, 17:24
Цитата Сообщение от Lers Посмотреть сообщение
Требуют так, в образовательных целях))
Требовать такое в образовательных целях - чистой воды вредительство.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.01.2016, 17:24
Помогаю со студенческими работами здесь

Указать максимальную разность между двумя соседними элементами массива и выделить при выводе эти элементы красным цветом
Задача 3.1. Заполнить одномерный массив из 15 элементов целыми числами. Указать максимальную разность между двумя соседними элементами...

Найти максимальную разницу между соседними элементами
Найти максимальную разницу между соседними элементами списка

Найти разность между соседними элементами вектора
напишите пожалуйста, как это сделать

Найти наибольшую по модулю разность между соседними элементами
Здравствуйте. Помогите с задачей. Дан одномерный массив. Найти наибольшую по модулю разность между соседними элементами. Спасибо!

Найти максимальную разницу времени между соседними объектами в первых 5-ти элементах коллекции
Добрый день! С Linq работал не очень много, поэтому прошу помощи профессионалов. Создана коллекция sequences, каждый элемент...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru