Solved

java lists

Posted on 2004-09-29
8
220 Views
Last Modified: 2010-04-17
how can I find the second highest value in a list of integers? and also the second lowest ?
0
Comment
Question by:rwallacej
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
8 Comments
 
LVL 1

Assisted Solution

by:djspinnet
djspinnet earned 200 total points
ID: 12179369
to find the second highest,

declare two variables max and second_max

1) traverse the list
2) store the first integer in max
3) if the next int (let's call it x) is larger than max, assign second_max = max; and max = x;
4) continue traversing the whole list and performing the same operation
5) return second_low

same goes for second lowest, just change >= to <=
0
 
LVL 1

Accepted Solution

by:
csaba_b earned 300 total points
ID: 12180266
Hi djspinnet!
your solution won't work for the following list: 2, 1 ... sorry

my proposal is:

suppose the list contains at leas 2 members and in case when two members has the highest value, the second highest equals the highest :)

int max = ((Integer)list.next()).intValue();
int max2 = ((Integer)list.next()).intValue();
int mxc = max2;
while(true) {
  if(mxc>=max) {
    mx2 = max;
    max = mxc;
  } else if(mxc>max2) {
    max2 = mxc;
  }
  if(!list.hasNextt()) {
    break;
  }
  mxc = ((Integer)list.next()).intValue();
}

for the second lowest you just replace > with <

csaba
0
 
LVL 21

Expert Comment

by:MogalManic
ID: 12180827
If speed is not an issue, just sort the list and grab the 2nd and 2nd from last item from the list
        Collections.sort(l);
        small=l.get(1);
        large=l.get(l.size()-2);
0
 
LVL 1

Expert Comment

by:djspinnet
ID: 12188464
actually, my solution did work - i implemented it once ;)
0
 
LVL 1

Expert Comment

by:csaba_b
ID: 12402861
To djspinnet:

Have you tried your algorithm with the list I mentioned? If yes, and the result was correct. you can accept the points offered.

I don't think so ...

Csaba
0

Featured Post

On Demand Webinar: Networking for the Cloud Era

Ready to improve network connectivity? Watch this webinar to learn how SD-WANs and a one-click instant connect tool can boost provisions, deployment, and management of your cloud connection.

Question has a verified solution.

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

Since upgrading to Office 2013 or higher installing the Smart Indenter addin will fail. This article will explain how to install it so it will work regardless of the Office version installed.
In this post we will learn how to make Android Gesture Tutorial and give different functionality whenever a user Touch or Scroll android screen.
Viewers will learn how to properly install Eclipse with the necessary JDK, and will take a look at an introductory Java program. Download Eclipse installation zip file: Extract files from zip file: Download and install JDK 8: Open Eclipse and …
With the power of JIRA, there's an unlimited number of ways you can customize it, use it and benefit from it. With that in mind, there's bound to be things that I wasn't able to cover in this course. With this summary we'll look at some places to go…

729 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