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

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

Версия для печати  Отправить по электронной почте    « Предыдущая тема | Следующая тема »  
Опции темы Опции просмотра
 
Создать новую тему Ответ
Старый 28.04.2014, 18:26
Akopalipsis вне форума Посмотреть профиль Найти все сообщения от Akopalipsis
  № 21  
Ответить с цитированием
Akopalipsis
Banned
[+4 24.02.14]
[+4 07.11.13]
[+ 13.03.14]

Регистрация: Mar 2013
Сообщений: 1,864
Меньше чем в этом. А тот где сравнивается с in лучше чем Ваш, быстрее в несколько раз.
Код AS3:
var value:int = 0;
for (var i = 1; i <= n; i++) {
	value += i;
	if (i - 1 < array.length) value -= array[i - 1];
}
trace("Удаленное число " + value);

Старый 28.04.2014, 18:28
ZackMercury вне форума Посмотреть профиль Отправить личное сообщение для ZackMercury Найти все сообщения от ZackMercury
  № 22  
Ответить с цитированием
ZackMercury
 
Аватар для ZackMercury

блогер
Регистрация: Jul 2013
Адрес: Север
Сообщений: 1,918
Записей в блоге: 23
Отправить сообщение для ZackMercury с помощью ICQ Отправить сообщение для ZackMercury с помощью Skype™
Цитата:
Сообщение от Akopalipsis Посмотреть сообщение
А тот где сравнивается с in лучше чем Ваш, быстрее в несколько раз.
Ну так вы мой код и оптимизировали. А это уже командная работа.
__________________
There is no thing in this world that is not simple.

Старый 28.04.2014, 18:36
PsixokoT вне форума Посмотреть профиль Отправить личное сообщение для PsixokoT Найти все сообщения от PsixokoT
  № 23  
Ответить с цитированием
PsixokoT

Регистрация: May 2008
Сообщений: 63
Цитата:
Сообщение от Akopalipsis Посмотреть сообщение
Меньше чем в этом. А тот где сравнивается с in лучше чем Ваш, быстрее в несколько раз.
вы сильно ошибаетесь в силу того, что не знаете как устроена работа indexOf.

запустите у себя код:
Код AS3:
var n:int = 1000000;
trace("N = " + n);
var array:Array = [];
for (var i:int = 1; i <= n; i++) {
	array.push(i);
}
 
var rand:int = Math.random() * n;
var num:int = array.splice(rand, 1);
trace("Удалили число " + num);
array.sort(function(...args):int {
	return Math.random() > 0.5 ? -1 : 1;
});
 
var t:Number = getTimer();
 
//1 способ
var value:Number = 0;
for (i = 1; i <= n; i++) {
	value += i;
	if (i - 1 < array.length) value -= array[i - 1];
}
 
trace("Удаленное число(1 способ) = " + value);
trace("time = " + (getTimer() - t));
 
t = getTimer();
 
//2 способ
for(i = 1; i <= array.length + 1; i++) {
	if(array.indexOf(i) < 0) {
		trace("Удаленное число(1 способ)  = " + i);
		trace("time = " + (getTimer() - t));
	}
}

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

блогер
Регистрация: Jul 2013
Адрес: Север
Сообщений: 1,918
Записей в блоге: 23
Отправить сообщение для ZackMercury с помощью ICQ Отправить сообщение для ZackMercury с помощью Skype™
Akopalipsis, я, конечно, не знаю насчёт in, но вот это
Код AS3:
var array:Array = [];
for(var j:int = 1; j <= 100; j ++)
	array.push(j);
array.splice(array.indexOf(3),1);
array.splice(array.indexOf(40),1);
 
trace(findMissingIntegers(array, 2));
 
function findMissingIntegers(arr:Array, missingNum:int = 0):Array
{
	var missingArr:Array = [];
 
	for(var i:int = 1; i <= arr.length + missingNum; i++)
	{
		if(!i in arr) missingArr.push(i);
	}
 
	return missingArr;
}
Не работает.
Код AS3:
var array:Array = [];
for(var j:int = 1; j <= 100; j ++)
	array.push(j);
array.splice(array.indexOf(3),1);
array.splice(array.indexOf(40),1);
 
trace(findMissingIntegers(array, 2));
 
function findMissingIntegers(arr:Array, missingNum:int = 0):Array
{
	var missingArr:Array = [];
 
	for(var i:int = 1; i <= arr.length + missingNum; i++)
	{
		if(!(i in arr)) missingArr.push(i);
	}
 
	return missingArr;
}
Это выдаёт 98, 99, 100,
Код AS3:
var array:Array = [];
for(var j:int = 1; j <= 100; j ++)
	array.push(j);
array.splice(array.indexOf(3),1);
array.splice(array.indexOf(40),1);
 
trace(findMissingIntegers(array, 2));
 
function findMissingIntegers(arr:Array, missingNum:int = 0):Array
{
	var missingArr:Array = [];
 
	for(var i:int = 1; i <= arr.length + missingNum; i++)
	{
		if(arr.indexOf(i) < 0) missingArr.push(i);
	}
 
	return missingArr;
}
А это работает как положено и выдаёт 3 и 40.

Добавлено через 13 минут
Вот, в общем, самый найменее громоздкий и простой для понимания код, а главное работающий, по поиску удалённых чисел.
Код AS3:
function findMissingIntegers(arr:Array, missingNum:int = 0):Array
{
	var missingArr:Array = [];
	for(var i:int = 1; i <= arr.length + missingNum; i++)
		if(arr.indexOf(i) < 0) missingArr.push(i);
	return missingArr;
}
__________________
There is no thing in this world that is not simple.


Последний раз редактировалось ZackMercury; 28.04.2014 в 19:36.
Старый 28.04.2014, 19:40
toFL вне форума Посмотреть профиль Найти все сообщения от toFL
  № 25  
Ответить с цитированием
toFL
Banned

Регистрация: May 2011
Адрес: +48° 27' 57.93", +35° 2' 46.02"
Сообщений: 447
Записей в блоге: 2
Отправить сообщение для toFL с помощью Skype™
Вот, если прибегать к формуле арифметической прогрессии:
Код AS3:
private function find(list:Array):int
{
	var summ:int;
	var len:int = list.length + 1;
	for (var i:int = 0; i < len - 1; ++i) summ += list[i];
	return (((1+len)/2) * len) - summ;
}


Последний раз редактировалось toFL; 28.04.2014 в 19:54.
Старый 28.04.2014, 19:45
ZackMercury вне форума Посмотреть профиль Отправить личное сообщение для ZackMercury Найти все сообщения от ZackMercury
  № 26  
Ответить с цитированием
ZackMercury
 
Аватар для ZackMercury

блогер
Регистрация: Jul 2013
Адрес: Север
Сообщений: 1,918
Записей в блоге: 23
Отправить сообщение для ZackMercury с помощью ICQ Отправить сообщение для ZackMercury с помощью Skype™
Цитата:
Сообщение от toFL Посмотреть сообщение
Вот, если прибегать к формуле арифметической прогрессии:
Код AS3:
private function find(list:Array):int
{
	var summ:int;
	var len:int = list.length;
	for (var i:int = 0; i < len; ++i) summ += list[i];
	return (((1+len)/2) * len) - summ;
}
Вот это
Код AS3:
var array:Array = [];
for(var j:int = 1; j <= 100; j ++)
	array.push(j);
array.splice(array.indexOf(40),1);
 
trace(findMissingIntegers(array, 1));
trace(find(array));
 
function find(list:Array):int
{
	var summ:int;
	var len:int = list.length;
	for (var i:int = 0; i < len; ++i) summ += list[i];
	return (((1+len)/2) * len) - summ;
}
 
function findMissingIntegers(arr:Array, missingNum:int = 0):Array
{
	var missingArr:Array = [];
	for(var i:int = 1; i <= arr.length + missingNum; i++)
		if(arr.indexOf(i) < 0) missingArr.push(i);
	return missingArr;
}
у меня выбивает
Код:
40
-60
__________________
There is no thing in this world that is not simple.

Старый 28.04.2014, 19:54
toFL вне форума Посмотреть профиль Найти все сообщения от toFL
  № 27  
Ответить с цитированием
toFL
Banned

Регистрация: May 2011
Адрес: +48° 27' 57.93", +35° 2' 46.02"
Сообщений: 447
Записей в блоге: 2
Отправить сообщение для toFL с помощью Skype™
Обновил пост, забыл ++ поставить. Проверяй.

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

блогер
Регистрация: Jul 2013
Адрес: Север
Сообщений: 1,918
Записей в блоге: 23
Отправить сообщение для ZackMercury с помощью ICQ Отправить сообщение для ZackMercury с помощью Skype™
Пример со встряхиванием массива:
Код AS3:
var arr:Array = [];
for (var j:int = 1; j <= 100; j ++)
{
	arr.push(j);
}
 
var array:Array = arrayShuffle(arr);
trace(array);
 
array.splice(array.indexOf(40),1);
 
 
trace(findMissingIntegers(array, 1));
trace(find(array));
 
function find(list:Array):int
{
	var summ:int;
	var len:int = list.length + 1;
	for (var i:int = 0; i < list.length; i++)
	{
		summ +=  list[i];
	}
	return (((1+len)/2) * len) - summ;
}
 
function findMissingIntegers(arr:Array, missingNum:int = 0):Array
{
	var missingArr:Array = [];
	for (var i:int = 1; i <= arr.length + missingNum; i++)
		if (arr.indexOf(i) < 0) missingArr.push(i);
	return missingArr;
}
 
function arrayShuffle(arr:Array):Array
{
	var newArr:Array = [];
	while (arr.length > 0)
	{
		newArr.push(arr.splice(Math.round(Math.random() * (arr.length - 1)), 1)[0]);
	}
	return newArr;
}
__________________
There is no thing in this world that is not simple.

Старый 28.04.2014, 21:19
Akopalipsis вне форума Посмотреть профиль Найти все сообщения от Akopalipsis
  № 29  
Ответить с цитированием
Akopalipsis
Banned
[+4 24.02.14]
[+4 07.11.13]
[+ 13.03.14]

Регистрация: Mar 2013
Сообщений: 1,864
SuriTheAngel вы были правы! С in не работает, так-как in показывает ключи.
я почему-то думал что в массивах он показывает элементы.
toFL Огромное Вам Спасибо! Лучше кода и быть не может.

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

блогер
Регистрация: Jul 2013
Адрес: Север
Сообщений: 1,918
Записей в блоге: 23
Отправить сообщение для ZackMercury с помощью ICQ Отправить сообщение для ZackMercury с помощью Skype™
Вот вам ещё один способ поиска удалённых чисел, но его недостаток в том, что если отсутствует последнее число, то этого он не замечает, ибо настоятельно длина предыдущего массива не задаётся(хотя если это обязательно, то можно и сделать так)
Без indexOf.
Код AS3:
function findAllMissedIntegers(arr:Array):Array
{
	arr.sort(Array.NUMERIC);
	var missingArr:Array = [];
	for(var i:int = 0; i < arr.length; i ++)
	{
		if((arr[i] + 1) != (arr[i + 1]) && arr[i + 1]) 
		{
			arr.splice(i + 1, 0, arr[i] + 1);
			missingArr.push(arr[i + 1]);
		}
	}
	return missingArr;
}
__________________
There is no thing in this world that is not simple.

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

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

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


 


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


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