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

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

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

Регистрация: Aug 2013
Сообщений: 7
По умолчанию Быстро перемешать символы в строке

Добрый день, столкнулся с задачей перемешивания символов в строчке размером в сотню мегабайт.
Привет -> рПвите

Само собой при помощи цикла, строчек и getCharAt это все происходит _очень_ медленно (порядка 2 минут) и сжирает феерический объем оперативы.

Код AS3:
if (!(length % 2 == 1))
				{
					while (i < length)
					{
						s += base64.charAt(i + 1) + base64.charAt(i);
						i+=2;
					}
				}
				else
				{
					while (i < length - 1)
					{
						s += base64.charAt(i + 1) + base64.charAt(i);
						i += 2;
					}
					s += base64.charAt(base64.length-1);
				}
 
				return s;
Начал копать в сторону байтаррея, через какое-то время написал решение, но по скорости оно не выигрывает и имеет какие-то проблемы с кодировкой
Код AS3:
var b_temp:ByteArray = new ByteArray();
				var bytes:ByteArray = new ByteArray();
				bytes.writeUTFBytes(base64);
 
				if (!(length % 2 == 1))
				{
					for (i = 0; i < bytes.length-2; i+=4)
					{				
						b_temp.writeByte(bytes[i + 2]);
						b_temp.writeByte(bytes[i + 3]);
 
						b_temp.writeByte(bytes[i]);
						b_temp.writeByte(bytes[i+1]);
					}
				}
				else
				{
					for (i = 0; i < bytes.length - 4; i += 4)
					{				
						b_temp.writeByte(bytes[i + 2]);
						b_temp.writeByte(bytes[i + 3]);
 
						b_temp.writeByte(bytes[i]);
						b_temp.writeByte(bytes[i+1]);
					}
					b_temp.writeByte(bytes[bytes.length - 2]);
					b_temp.writeByte(bytes[bytes.length - 1]);
				}
Прошу помогите добиться наиболее быстрого алгоритма.

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

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

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


 


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


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