С Новым годом! Форум программистов, компьютерный форум, киберфорум
Java для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/18: Рейтинг темы: голосов - 18, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 14.06.2015
Сообщений: 4
1

Сортировка методом Шелла

16.01.2016, 21:33. Показов 3458. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Ребят, дали задание сделать сортировку массива методом Шелла с убывающим шагом. Получилось что то такое. Но после сортировки пропадает одна цифра, может я что не понимаю. Исправьте что не так пожалуйста.

Java
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
package javaapplication21;
import java.util.Random;
import java.util.Scanner;
public class sorting {
    public static void main(String[] args) {
 Scanner sc = new Scanner(System.in);
        int tmp, j, i, n, d, ch;
         System.out.print("Введите число элементов массива n=");
        n = sc.nextInt();
         int matrix[] = new int[n];
         System.out.print("Исходный массив:");
         Random Rand = new Random();
         for (i = 0; i < n; i++) {
            matrix[i] = Rand.nextInt(n);
            System.out.print(" " + matrix[i]);
        }
         d = n;
        d = d / 2;
        while (d > 0) {
            for (i = 1; i < n - d; i++) {
                j = i;
                while (j > 0 && matrix[j] > matrix[j + d]) {
                    ch = matrix[j];
                    matrix[j] = matrix[j + d];
                    matrix[j + d] = ch;
                    j--;
                }
            }
            d = d / 2;
        }
        System.out.println( );
        System.out.print("Сортированный массив: ");
        for (i = 1; i < n; i++) {
               System.out.print(" " + matrix [i]);
        }
           }
       }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.01.2016, 21:33
Ответы с готовыми решениями:

Сортировка методом Шелла не работает
import java.io.File; import java.io.FileNotFoundException; import java.util.Scanner; import...

Быстрая сортировка и сортировка Шелла
есть трудности с быстрой сортировкой и сортировкой Шелла также нужен их сравнительный анализ

Сортировка Шелла
package Dulati; import java.util.Scanner; import java.util.Arrays; public class Main { ...

Сортировка Шелла!
Помогите исправить код! Нужно сортировать массив методом Шелли. package laba2; import...

3
323 / 310 / 206
Регистрация: 14.09.2015
Сообщений: 827
16.01.2016, 23:05 2
DeathAdept, вероятнее всего вот здесь d = d / 2 теряется единица поскольку, к примеру (int) 5 / (int) 2 = 2, а не 2,5 - ведь это уже double. Вроде больше ни чего такого криминального не видно. Для проверки попробуйте массив из 16 элементов - кажется не должно ни чего пропасть.

Добавлено через 34 минуты
Вот бы сразу отформатированный код разместили, и ошибку бы было легче найти: строка 33 for (i = 0; ... (а не 1 как у автора)

Добавлено через 8 минут
Исправление строке 33 возвращает потерянный элемент, но оказывается, что сортировка начинается не с первого элемента, а со второго. Подсказывать где скрывается очередная ошибка, или сами искать станете?
0
0 / 0 / 0
Регистрация: 14.06.2015
Сообщений: 4
16.01.2016, 23:42  [ТС] 3
подскажите пожалуйста))))
0
323 / 310 / 206
Регистрация: 14.09.2015
Сообщений: 827
16.01.2016, 23:55 4
Ok! Смотрите строчку 22: while (j > 0 &&... нужно сделать >= тогда всё должно заработать так, как ожидается.
0
16.01.2016, 23:55
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.01.2016, 23:55
Помогаю со студенческими работами здесь

Сортировка методом Шелла и быстрая сортировка
Помогите найти код для функций в виде кусков кода сортировок...

Сортировка методом Шелла
Привет! Помогите составить процедуру сортировки Шелла с убывающим шагом. Сортировать нужно...

Сортировка методом Шелла
Помогите! Нужно написать код программы сортировки одномерного массива по убыванию методом Шелла....

Сортировка методом Шелла
Помогите с написанием программы, которая реализует сортировку массива методом шелла...я только...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
Что такое NullReferenceEx­­­ception и как исправить?
InfoMaster 08.01.2025
NullReferenceException - одно из самых распространенных исключений, с которым сталкиваются разработчики на C#. Это исключение возникает при попытке обратиться к членам объекта (методам, свойствам или. . .
Что такое Null Pointer Exception (NPE) и как это исправить?
InfoMaster 08.01.2025
Null Pointer Exception (NPE) - это одно из самых распространенных исключений в Java, которое возникает при попытке использовать ссылку на объект, значение которой равно null. Это исключение относится. . .
Русский язык в консоли C++
InfoMaster 08.01.2025
При разработке программ на C++ одной из частых проблем, с которой сталкиваются русскоязычные программисты, является корректное отображение кириллицы в консольных приложениях. Эта проблема особенно. . .
Telegram бот на C#
InfoMaster 08.01.2025
Разработка ботов для Telegram стала неотъемлемой частью современной экосистемы мессенджеров. C# предоставляет мощный и удобный инструментарий для создания разнообразных ботов, от простых. . .
Использование GraphQL в Go (Golang)
InfoMaster 08.01.2025
Go (Golang) является одним из наиболее популярных языков программирования, используемых для создания высокопроизводительных серверных приложений. Его архитектурные особенности и встроенные. . .
Что лучше использовать при создании класса в Java: сеттеры или конструктор?
Alexander-7 08.01.2025
Вопрос подробнее: На вопрос: «Когда одновременно создаются конструктор и сеттеры в классе – это нормально?» куратор уточнил: «Ваш класс может вообще не иметь сеттеров, а только конструктор и геттеры. . .
Как работать с GraphQL на TypeScript
InfoMaster 08.01.2025
Введение в GraphQL и TypeScript В современной разработке веб-приложений GraphQL стал мощным инструментом для создания гибких и эффективных API. В сочетании с TypeScript, эта технология. . .
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru