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

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

16.01.2016, 21:33. Показов 3451. Ответов 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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
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
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
16.01.2016, 23:55
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru