Форум Flasher.ru
Ближайшие курсы в Школе RealTime
Список интенсивных курсов: [см.]  
  
Специальные предложения: [см.]  
  
 
Блоги Правила Справка Пользователи Календарь Поиск рулит! Сообщения за день Все разделы прочитаны
 

Вернуться   Форум Flasher.ru > Flash > ActionScript 3.0

Версия для печати  Отправить по электронной почте    « Предыдущая тема | Следующая тема »  
Опции темы Опции просмотра
 
Создать новую тему Ответ
Старый 18.04.2011, 20:53
Universe вне форума Посмотреть профиль Отправить личное сообщение для Universe Найти все сообщения от Universe
  № 1  
Ответить с цитированием
Universe
 
Аватар для Universe

Регистрация: Feb 2010
Сообщений: 811
Отправить сообщение для Universe с помощью ICQ Отправить сообщение для Universe с помощью Skype™
Arrow Непонятная пузырьковая сортировка

Всем привет!
Пытаюсь разобраться с пузырьковой сортировкой, и она вроде бы работает, но как то алогично, т.е. реверсивно.
Код AS3:
var arr:Array = [8,4,10];
sort();
 
function sort():void
{
	 for(var i:int = 0; i < arr.length; i++)
	 {
	  	for(var j:int = 0; j < arr.length; j++)
		{
		  if(arr[i] < arr[j])
		   {
			var temp:Number = arr[j];
			arr[j] = arr[i];
			arr[i] = temp;
			}
		}
 	trace(arr);
	}
}
По-идее этот код должен сортировать цифры по убыванию, но он его сортирует по возрастанию! Почему?

Старый 18.04.2011, 21:09
GBee вне форума Посмотреть профиль Отправить личное сообщение для GBee Найти все сообщения от GBee
  № 2  
Ответить с цитированием
GBee
 
Аватар для GBee

Регистрация: Jan 2009
Сообщений: 3,067
Записей в блоге: 3
Отправить сообщение для GBee с помощью Skype™
Меньше вместо больше.
Какая-то кривая реализация. Элемент сам с собой сравнивается. arr.length каждый раз запрашивается.

Добавлено через 2 минуты
http://ru.wikipedia.org/wiki/%D0%A1%...BA%D0%BE%D0%BC
__________________
Чтобы доказать, что вы не робот, причините вред другому человеку.

Старый 18.04.2011, 21:24
Universe вне форума Посмотреть профиль Отправить личное сообщение для Universe Найти все сообщения от Universe
  № 3  
Ответить с цитированием
Universe
 
Аватар для Universe

Регистрация: Feb 2010
Сообщений: 811
Отправить сообщение для Universe с помощью ICQ Отправить сообщение для Universe с помощью Skype™
а как правильно?

Старый 18.04.2011, 21:31
Alex Lexcuk вне форума Посмотреть профиль Отправить личное сообщение для Alex Lexcuk Посетить домашнюю страницу Alex Lexcuk Найти все сообщения от Alex Lexcuk
  № 4  
Ответить с цитированием
Alex Lexcuk

блогер
Регистрация: Mar 2008
Адрес: Донецк_city
Сообщений: 1,094
Записей в блоге: 5
Тут посмотрите реализацию сортировки массива, может это то что надо
http://www.murmadillo.tut.su/as3/fas...-sort-as3.html
__________________
Гоночка

Старый 18.04.2011, 22:12
honest_man вне форума Посмотреть профиль Отправить личное сообщение для honest_man Найти все сообщения от honest_man
  № 5  
Ответить с цитированием
honest_man

Регистрация: Aug 2010
Сообщений: 86
Код AS3:
var arr:Array = [8,4,10];
sort();
 
function sort():void
{
	 for(var i:int = 0; i < arr.length; i++)
	 {
	  	for(var j:int = 0; j < arr.length; j++)
		{
		  if(arr[i] > arr[j]) //Вот как правильно
		   {
			var temp:Number = arr[j];
			arr[j] = arr[i];
			arr[i] = temp;
			}
		}
 	trace(arr);
	}
}

Старый 18.04.2011, 23:53
GBee вне форума Посмотреть профиль Отправить личное сообщение для GBee Найти все сообщения от GBee
  № 6  
Ответить с цитированием
GBee
 
Аватар для GBee

Регистрация: Jan 2009
Сообщений: 3,067
Записей в блоге: 3
Отправить сообщение для GBee с помощью Skype™
На вики нормально алгоритм описан

Цитата:
Вход: массив A, состоящий из элементов A[1], A[2], ..., A[n-1], A[n]

t := истина
цикл пока t:
t := ложь
цикл для j = 1, 2, ..., n − 1:
если A[j] > A[j+1], то:
обменять местами элементы A[j] и A[j+1]
t := истина
__________________
Чтобы доказать, что вы не робот, причините вред другому человеку.

Создать новую тему Ответ Часовой пояс GMT +4, время: 02:24.
Быстрый переход
  « Предыдущая тема | Следующая тема »  
Опции темы
Опции просмотра

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.


 


Часовой пояс GMT +4, время: 02:24.


Copyright © 1999-2008 Flasher.ru. All rights reserved.
Работает на vBulletin®. Copyright ©2000 - 2026, Jelsoft Enterprises Ltd. Перевод: zCarot
Администрация сайта не несёт ответственности за любую предоставленную посетителями информацию. Подробнее см. Правила.