a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > Perl > 正文

Perl數(shù)組排序?qū)W習(xí)筆記

2020-10-31 14:51:24
字體:
供稿:網(wǎng)友

本文我們學(xué)習(xí)如何用Perl對(duì)字符串或者數(shù)字?jǐn)?shù)組進(jìn)行排序。

Perl有個(gè)內(nèi)置函數(shù)叫做sort毫無疑問的可以排序一個(gè)數(shù)組。 其最簡單的形式是傳遞一個(gè)數(shù)組,它會(huì)返回排序后的元素組成的數(shù)組。@sorted = sort @original。

基于ASCII碼排序

復(fù)制代碼 代碼如下:

#!/usr/bin/perl
use strict;
use warnings;
use 5.010;
 
use Data::Dumper qw(Dumper);
 
my @words = qw(foo bar zorg moo);
 
say Dumper /@words;
 
my @sorted_words = sort @words;
 
say Dumper /@sorted_words;

上邊的例子將會(huì)打印
復(fù)制代碼 代碼如下:

$VAR1 = [
        'foo',
        'bar',
        'zorg',
        'moo'
      ];
 
$VAR1 = [
        'bar',
        'foo',
        'moo',
        'zorg'
      ];

第一個(gè)輸出顯示了排序前的數(shù)組,第二個(gè)是排序后的。

這是最簡單的情形,但是可能未必是你想要的。 比如,如果一些單詞以大寫字母開頭怎么辦?

復(fù)制代碼 代碼如下:

my @words = qw(foo bar Zorg moo);
@sorted_names里的結(jié)果將是:

$VAR1 = [
        'Zorg',
        'bar',
        'foo',
        'moo'
      ];


你會(huì)發(fā)現(xiàn),以大寫字母開頭的單詞排在了第一位。 這是因?yàn)閟ort默認(rèn)根據(jù)ASCII碼表排序,所有的大寫字母都排在小寫字母前邊。

比較函數(shù)

Perl的sort的工作方式是這樣的,它遍歷原始數(shù)組的每兩個(gè)元素;每次把左邊的值放入變量$a,把右邊的值放入變量$b。 然后調(diào)用比較函數(shù)。如果$a的內(nèi)容應(yīng)該在左邊的話,“比較函數(shù)”會(huì)返回1;如果$b應(yīng)該在左邊的話,返回-1,兩者一樣的話,返回0。

通常你看不到比較函數(shù),sort會(huì)根據(jù)ASCII碼表對(duì)值進(jìn)行比較,不過如果你想的話,你可以顯式的寫出來:

復(fù)制代碼 代碼如下:

sort { $a cmp $b } @words;

這段代碼會(huì)跟沒有使用塊的sort @words達(dá)到同樣的效果。

這里你可以看到,默認(rèn)perl使用cmp作為比較函數(shù)。這是因?yàn)檎莄mp可以做這里邊我們需要的工作。 它比較兩邊的字符串的值,如果左邊參數(shù)“小于”右邊參數(shù),就返回1;如果左邊參數(shù)“大于”右邊參數(shù),就返回-1;如果相等,就返回0。

按字母順序排列
如果你想忽略字符串的大小寫來排序――即通常所謂的字母序,你可以像下一個(gè)例子這么做:

復(fù)制代碼 代碼如下:

my @sorted_words = sort { lc($a) cmp lc($b) } @words;

這里為了比較,我們調(diào)用lc函數(shù)返回參數(shù)的小寫版本。然后cmp比較這些小寫版本并決定原始字符串誰先誰后。

結(jié)果是

復(fù)制代碼 代碼如下:

$VAR1 = [
        'bar',
        'foo',
        'moo',
        'Zorg'
      ];

Perl對(duì)數(shù)值排序
如果對(duì)數(shù)值數(shù)組使用sort進(jìn)行默認(rèn)的排序,結(jié)果可能不是我們期望的。

復(fù)制代碼 代碼如下:

my @numbers = (14, 3, 12, 2, 23);
my @sorted_numbers = sort @numbers;
say Dumper /@sorted_numbers;
$VAR1 = [
        12,
        14,
        2,
        23,
        3
      ];

仔細(xì)一想的話,這并不奇怪。比較函數(shù)看到12和3時(shí),它按字符串進(jìn)行比較。這意味著比較兩個(gè)字符串的第一個(gè)字符"1"和"3"。 在ASCII碼表里,"1"在"3"前邊,因此字符串"12"會(huì)排在字符串"3"前面。

Perl不會(huì)很神奇地猜到你想按數(shù)字對(duì)這些值排序。

盡管我們可以寫一個(gè)比較函數(shù)來按數(shù)字比較兩個(gè)值。但這里我們使用<=>(也被稱作宇宙飛船操作符), 它會(huì)按數(shù)字來比較兩個(gè)參數(shù)并返回1、-1或者0。

復(fù)制代碼 代碼如下:

my @sorted_numbers = sort { $a <=> $b } @numbers;

結(jié)果是:

復(fù)制代碼 代碼如下:

$VAR1 = [
        2,
        3,
        12,
        14,
        23
      ];

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 亚洲六月丁香色婷婷综合久久 | 精品久久久久久久久久 | 久久99精品国产91久久来源 | 色屁屁草草影院ccyycom | 成人午夜视频在线观看 | 91久久国产综合久久 | 九色在线 | 午夜精品一区二区三区免费视频 | 毛片网 | 中文字幕91| 最新日韩精品在线观看 | 99精品九九| 欧美中文字幕一区二区 | 最新黄色网页 | 久久成人综合网 | 99精品欧美一区二区三区 | 麻豆精品国产91久久久久久 | 一本色道久久综合亚洲精品不卡 | 中文亚洲欧美 | 欧美午夜影院 | 亚洲小视频网站 | 欧美性一区二区三区 | 红杏aⅴ成人免费视频 | 国产综合99 | 成人黄色免费网站 | 密室大逃脱第六季大神版在线观看 | 久久成人精品一区二区三区 | 国产精品资源在线 | 精品国语 | 人人澡人人草 | 午夜国产一级 | av水蜜桃 | 日本精品视频网站 | a级三四级黄大片 | 色婷婷影院 | 福利在线看 | 亚洲天堂一区二区 | 亚洲www| 成人一区二区在线 | 不卡在线 | 欧美日韩视频在线 |