Solved

Sortting an array

Posted on 2009-07-08
6
264 Views
Last Modified: 2013-12-25
I have a list of names like this.

[0]Bob
[1]Joe
[2]Bob
[3]Bob
[4]Bob
[5]Joe
[6]Phil
[7]Phil

I want to sort my array without changing it so that its like this (so basically give an alternative index of elements so its like this):

[0]Bob
[2]Bob
[3]Bob
[4]Bob
[1]Joe
[5]Joe
[6]Phil
[7]Phil

#Class contains the name information.
 

$m=0;

$no=0;

$kl =0;

@keep=();
 

foreach (@Class){

	$test = $no;

		foreach $u (0..$#keep){

			if ($_=~m/$keep[$u]/){

				$no++;

			} elsif ($_ =~ m/^[ \t]*$/){

				$Class[$m]="CHECK MANUALLY";

			}

		}

		if ($no==$test){

		$keep[$kl] = $_;

		$kl++;

		}

	$m++;

}
 

@keep2=();

@index =();

$indcount=0;

foreach $hu (@keep){
 

	foreach $ij (0..$#Class){

		if ($Class[$ij] =~ m/$hu/){

			$index[$indcount]=$ij;

			$indcount++;

		}

	}

	

}

Open in new window

0
Comment
Question by:sanjangeorge
6 Comments
 
LVL 13

Expert Comment

by:kawas
ID: 24804265
To sort an array in ASCII (Alphabetical) order :
sort(@array);

Example of storing a sort result back into the same array :
@array = sort (@array);

To sort an array in reverse ASCII (Alphabetical) order :
sort {$b cmp $a} (@array);

To sort an array in numeric ascending order :
sort {$a <=> $b} (@array);

To sort an array in numeric decending order :
sort {$b <=> $a} (@array);

To print a sorted array but not alter the original :
print sort(@array);

To reverse the value elements in an array :
reverse (@array);


from http://www.htmlite.com/perl016.php
0
 

Author Comment

by:sanjangeorge
ID: 24804300
Yeah i've seen things like this not quite what im looking for
0
 
LVL 13

Expert Comment

by:kawas
ID: 24804351
if you are trying to sort the arrays and keep indices (old and new) maybe the data structure you are using isnt correct for you.
0
3 Use Cases for Connected Systems

Our Dev teams are like yours. They’re continually cranking out code for new features/bugs fixes, testing, deploying, testing some more, responding to production monitoring events and more. It’s complex. So, we thought you’d like to see what’s working for us.

 
LVL 11

Expert Comment

by:climbgunks
ID: 24804470

#!/usr/bin/perl -w

use strict;
 

my @unsorted = (

             "[0]Bob",

             "[1]Joe",

             "[2]Bob",

             "[3]Bob",

             "[4]Bob",

             "[5]Joe",

             "[6]Phil",

             "[7]Phil"

             );
 

my @sorted = sort {

   $a =~ /^\[(\d+)\](.*)$/ or die "input $a not in expected form\n";

   my ($a1, $a2) = ($1, $2);

   $b =~ /^\[(\d+)\](.*)$/ or die "input $b not in expected form\n";

   my ($b1, $b2) = ($1, $2);

   $a2 eq $b2 ? $a1 <=> $b1 : $a2 cmp $b2;

} @unsorted;
 

print join("\n", @sorted)."\n";

Open in new window

0
 
LVL 39

Accepted Solution

by:
Adam314 earned 500 total points
ID: 24804571

my @Unsorted = qw(Bob Joe Bob Bob Bob Joe Phil Phil);

print "array=\n" . join("",map {"    [$_]$Unsorted[$_]\n"} (0..$#Unsorted));
 

my @indexes = sort {$Unsorted[$a] cmp $Unsorted[$b]} (0..$#Unsorted);

print "array=\n" . join("",map {"    [$_]$Unsorted[$_]\n"} @indexes[0..$#Unsorted]);

Open in new window

0
 
LVL 84

Expert Comment

by:ozo
ID: 24806972
my @unsorted = (
             "[0]Bob",
             "[1]Joe",
             "[2]Bob",
             "[3]Bob",
             "[4]Bob",
             "[5]Joe",
             "[6]Phil",
             "[7]Phil"
             );
$\=$/;
print for @sorted = map{/\0(.*)/}sort map{join"\0",(/([][\d]*(.*))/)[1,0]} @unsorted ;
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Email validation in proper way is  very important validation required in any web pages. This code is self explainable except that Regular Expression which I used for pattern matching. I originally published as a thread on my website : http://www…
This article will show, step by step, how to integrate R code into a R Sweave document
Learn the basics of while and for loops in Python.  while loops are used for testing while, or until, a condition is met: The structure of a while loop is as follows:     while <condition>:         do something         repeate: The break statement m…
The viewer will learn the basics of jQuery, including how to invoke it on a web page. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery.: (CODE)

863 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

22 Experts available now in Live!

Get 1:1 Help Now