一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - perl - Perl中著名的Schwartzian轉換問題解決實現

Perl中著名的Schwartzian轉換問題解決實現

2020-07-11 10:45perl教程網 perl

這篇文章主要介紹了Perl中著名的Schwartzian轉換問題解決實現,本文詳解講解了Schwartzian轉換涉及的排序問題,并同時給出實現代碼,需要的朋友可以參考下

Perl中著名的Schwartzian轉換,其產生背景主要涉及到排序問題:
比如說,根據文件名以字母順序排序,代碼如下:

復制代碼 代碼如下:

use strict; 
use warnings; 
  
my @files = glob "*.xml";          #perl中文件操作符glob提供相當于shell中的通配符的功能 
my @sorted_files = sort @files;    #sort(),排序,默認是字母順序排序


比如說,根據文件名長度排序,其代碼如下:

復制代碼 代碼如下:

use strict; 
use warnings; 
 
#length求長度。 太空船操作符<=>,默認變量是$a,$b,返回值為-1,0,1分別表示大于,==,小于。 sort進行排序 
my $files = ".xml"; 
my @sorted_length = sort { length($a) <=> length($b) } @files; 


上面的兩種情況,對很多文件操作來說,速度還不算慢,如果是下面這種情況。
比如說:要批量比較文件大小,其代碼如下:

復制代碼 代碼如下:

use strict; 
use warnings; 
  
my @files     = glob "*.xml";    
my @sort_size = sort { -s $a <=> -s $b } @files;  #比較大小 


上面的代碼設計到三重(次)操作:
1. 從硬盤上獲取文件大小(-s $b)
2. 比較文件大小(太空船操作)
3. 對其進行排序(sort操作)
考慮到要比較$a,$b大小時,要從硬盤中獲取兩次,所以次數是6次!也就是說,如果有1萬個文件,總共是6萬次。
其算法復雜度是: n*long(n),考慮到后兩項(比較文件大小,進行排序)必然要進行的操作,但第一項卻可以降低!
即一次性從硬盤中讀取所有文件大小,將其放置到Perl中的默認的變量,并存儲到內存中!于是又下面算法實現:

復制代碼 代碼如下:

use strict; 
use warnings; 
 
my @files = glob "*.xml"; 
 
my @unsorted_pairs = map  { [$_, -s $_] } @files; 
my @sorted_pairs   = sort { $a->[1] <=> $b->[1] } @unsorted_pairs; 
my @sorted_files   = map  { $_->[0] } @sorted_pairs; 


看上去比較復雜,分三個步驟解釋下:
第一步:遍歷文件列表,對每個文件創建一個數組引用。數組引用包含兩個元素:
       第一個是文件名($_),第二個是文件大小(-s $_)。這樣,處理每個文件只訪問一次磁盤。
第二步:對二維數組排序。因比較文件大小,所以需取元素[1],比較它們的值。得到另一個二維數組。
第三步:丟掉文件大小元素,創建一個只含文件名的列表。完成目標!
上面的代碼使用了兩個臨時數組,但這并不是必須的。我們可以一個語句就能完成所有的工作。為了達到目的,需要按照“數據從右流向左”的原理反轉句子順序,不如果將每個句子放在單獨一行,并且留出足夠的空間,我們依然可以寫出可讀性高的代碼。

復制代碼 代碼如下:

my @quickly_sorted_files = 
    map  { $_->[0] } 
    sort { $a->[1] <=> $b->[1] } 
    map  { [$_, -s $_] } 
    @files; 


這就是以Randal L. Schwartz命名的Schwartzian轉換,對數據量特多的情況下,其速度要比前者快數倍!
下面寫了小程序,包括在生成1萬個xml文件,在兩種情況下,完整代碼如下:

復制代碼 代碼如下:


#!/usr/bin/perl -w 
use strict; 
use warnings; 
use autodie; 
use v5.10; 
 
###################################### 
###  創建要比較的10,000個.xml文件 ### 
###################################### 
my $profix = ".xml"; 
 
foreach my $num (1..10000) { 
    open(my $fh, '>', $num . $profix) || die "Can not create the file: $!\n"; 
    print $fh "This is file size testing!"; 

 
print "All the 10_1000 files created! \n"; 
 
 
###################################### 
### 常規轉換:      遍歷20次       ### 
###################################### 
my $t1  = time(); 
 
foreach (1..20){  
    my @files     = glob "*.xml"; 
    my @sorted    = sort { -s $a <=> -s $b } @files; 

 
say "常規算法需要時間: => ", time()- $t1; 
 
 
###################################### 
### Schwartzian轉換: 遍歷20次     ### 
###################################### 
my $t2  = time(); 
 
foreach (1..20){  
    my @files = glob "*.xml"; 
        my @sorted =  
            map  {$_->[0]} 
            sort {$a->[1] <=> $b->[1]} 
            map  {[$_, -s $_]} 
       @files; 

 

say "Schwartzian算法需要時間: => ", time()- $t2; 

 

輸出結果:
All the 10_1000 files created!
常規算法需要時間:          => 185
Schwartzian算法需要時間: => 115

延伸 · 閱讀

精彩推薦
  • perlPerl的經典用法分享

    Perl的經典用法分享

    Perl的經典用法分享,學習perl的朋友可以參考下 ...

    腳本之家6562020-06-06
  • perlperl常見問題集合之二

    perl常見問題集合之二

    哪些平臺上有 Perl?要到哪里去找? Perl的標準發行版(由 perl 發展小組負責維護)僅以原始碼形式發行。您可在 http: //www.perl.com/CPAN/src/latest.tar.gz處取得。這個檔...

    腳本之家2102020-05-29
  • perlperl命令行參數內建數組@ARGV淺析

    perl命令行參數內建數組@ARGV淺析

    這篇文章主要介紹了perl命令行參數內建數組@ARGV淺析,本文重點在于講解@ARGV的用法,并通過實例來說明,需要的朋友可以參考下 ...

    perl教程網6162020-06-18
  • perlperl use vars pragma使用技巧

    perl use vars pragma使用技巧

    perl 中的vars是perl中的一個pragma(預編譯指示符),專門用來預定義全局變量,這些預定義后的全局變量在qw()列表中,在整個引用perl文件中皆可使用,即便使...

    perl教程網6812020-06-16
  • perlPerl使用nginx FastCGI環境做WEB開發實例

    Perl使用nginx FastCGI環境做WEB開發實例

    這篇文章主要介紹了Perl使用nginx FastCGI環境做WEB開發實例,實現了路由系統和模板系統,需要的朋友可以參考下...

    Perl教程網2412020-06-18
  • perlPerl從文件中讀取字符串的兩種實現方法

    Perl從文件中讀取字符串的兩種實現方法

    有時候我們需要從文件中讀取字符串,這里簡單介紹下, 需要的朋友可以參考下 ...

    腳本之家6252020-06-08
  • perlperl pop push shift unshift實例介紹

    perl pop push shift unshift實例介紹

    perl的pop跟push操作數組的最右邊,shift跟unshift操作數組的最左邊 ...

    腳本之家4612020-06-10
  • perlPerl List::Util模塊使用實例

    Perl List::Util模塊使用實例

    這篇文章主要介紹了Perl List::Util模塊使用實例,本文給出掃描符合條件的某個列表并取出第一個符合條件的、求1到1000之間的和 、求一組數字的最大值與最小...

    腳本之家4712020-06-22
主站蜘蛛池模板: 精品国产一区二区三区久久久狼 | 欧美日韩高清完整版在线观看免费 | 女子监狱第二季在线观看免费完整版 | 福利视频导航大全 | 日本视频在线观看播放 | 日韩欧美亚洲天堂 | 免费在线观看日本 | 精品亚洲国产一区二区 | 精品国产精品国产偷麻豆 | 亚洲精品一区波多野结衣 | 成人男女啪啪免费观看网站 | 亚洲欧美专区精品久久 | 日本中文字幕一区二区有码在线 | 精品国产成人 | blackedvideos黑人| 美女一级ba大片免色 | 亚洲AV无码国产精品色在线看 | 九九99热久久精品在线6 | 亚洲邪恶天堂影院在线观看 | 成年人黄视频在线观看 | 国产一线天 | 国模大胆一区二区三区 | 91在线精品视频 | 国产一卡二卡3卡4卡更新 | 俄罗斯精品bbw | 91精品国产91久久久久久麻豆 | 日本在线小视频 | 交换性关系中文字幕6 | 91在线精品老司机免费播放 | 国产婷婷综合丁香亚洲欧洲 | 1024在线视频精品免费 | 男人天堂网页 | 欧美一级视频在线 | 性关系视频免费网站在线观看 | 国产免费专区 | 973影院 | 我要看黄色毛片 | 好大好硬好深好爽想要小雪 | 精品国产mmd在线观看 | 日韩手机在线观看 | 国产香蕉一区二区在线观看 |