Jump to content
  • 0

Fastlist -> Arraylist Acis


Question

Posted (edited)

http://imgur.com/a/1oYgm

protected int getWinnerTeam()
	{
		ArrayList<EventTeam> t = new ArrayList<>();
		
		for (EventTeam team : teams.values())
		{
			if (t.size() == 0)
			{
				t.add(team);
				continue;
			}
			
			if (team.getScore() > t.getFirst().getScore())
			{
				t.clear();
				t.add(team);
				continue;
			}
			
			if (team.getScore() == t.getFirst().getScore())
				t.add(team);
		}
		
		if (t.size() > 1)
			return 0;
		
		return t.getFirst().getId();
	}

getFirst () must be replaced by what?

Edited by L2shaken

Recommended Posts

  • 0
Posted
return t.get(0).getId();
	protected int getWinnerTeam()
	{
		ArrayList<EventTeam> t = new ArrayList<>();
		
		for (EventTeam team : teams.values())
		{
			if (t.size() == 0)
			{
				t.add(team);
				continue;
			}
			
			if (team.getScore() > t.get(0).getScore())
			{
				t.clear();
				t.add(team);
				continue;
			}
			
			if (team.getScore() == t.get(0).getScore())
				t.add(team);
		}
		
		if (t.size() > 1)
			return 0;
		
		return t.get(0).getId();
	}

right ?

  • 0
Posted

Right. But i would suggest you to take a look on the other posts and reconsider your course of action. This algorithm is very suboptimal, you should try to recode it or at least understand why.

  • 0
Posted (edited)

This community keeps going worse and worse, damn it.  :lol:

seriously,i reported him.
 
He has getScore() and compareTo(EventTeam second) but he wants to create a new sh1tcode, use unnecessary ArrayList and after that,he wants to ...
He doesnt use anything properly ...
Just report them or get 2 condoms for ur eyes 
Edited by bravetobe
  • 0
Posted

You say "he use" / "he wants".. No, he don't want to. How can he, if he can't do it / don't understand it. He is simply using some ready, old code.

 

Stop the drama. Like Versus said, it's a request help section, after all.

  • 0
Posted

You say "he use" / "he wants".. No, he don't want to. How can he, if he can't do it / don't understand it. He is simply using some ready, old code.

 

Stop the drama. Like Versus said, it's a request help section, after all.

Old code?I cant really believe that someone coded that thing and he actually decided to get that code and actually use it...

 

Besides,i dont want to see 1 more "BALANCED" server around + 1 more nazi admin in his own stupid forum who bans people Kappa.Also,me + one other dude told him 2 different ways to code that decently.

 

No haterino,make spaghettirino,plz make me cappucino

  • 0
Posted

I cant really believe that [...] he actually decided to get that code and actually use it...

As if he had other choice :lol:

 

No one wants.. :P

  • 0
Posted

Old code?I cant really believe that someone coded that thing and he actually decided to get that code and actually use it...

 

Besides,i dont want to see 1 more "BALANCED" server around + 1 more nazi admin in his own stupid forum who bans people Kappa.Also,me + one other dude told him 2 different ways to code that decently.

 

No haterino,make spaghettirino,plz make me cappucino

You're just jealous cause he is PRO jeva davaloper. HI MEIK PRO CODES 2K16

  • 0
Posted (edited)

Sad story. This man don't want to know the purpose of the code, but he asking for help in correcting the methods while they was written in the FastMap style. Also it's was not the better solution for this, and not ArrayList story.

 

I think this man will not be satisfed if we recommened him learn what this code doing. In this case, is not the help. It's work of other people - time, brains and hands.

 

My opinion - wrong section for request.

Edited by Rootware
  • 0
Posted (edited)

What would be the right way?

public int compareTo(EventTeam second)
	{
		if (getScore() > second.getScore())
			return 1;
		else if (getScore() < second.getScore())
			return -1;
		
		return 0;
	}

protected int getScore()
	{
		return score;
	}

protected int getId()
    {
        return id;
    }
    

There is code already which u can use instead of code something that u saw in ur sleep or something

 

Since i dont code things in l2j,i will try to make it as simple as i can tho (what i would do):

If its supposed to be more than X teams (x >>2):

Track down the team with the highest score.Since i dont know what kind of collection is this,dunno whats more efficient(dunno the methods but it looks like hashmap or what...arraylist fanboy).

Copy the team with the highest score into an object,and later on get the id.That might be the most easy way.

OR 

set highestScore=0 id =0,compare score that each team's score and if it has higher score than that,save the id and after the loop return it.

If its supposed to be with 2 teams:

Just get their scores and return the id.

 

Thats my prespective.No coding in l2j tho Kappa

 

- Editted several times to clarify how u can actually code it-

gl

 

P.S thats w/o 2 team same score.if 2 teams have same score,it becomes more tricky.

Edited by bravetobe
  • 0
Posted
public int compareTo(EventTeam second)
	{
		if (getScore() > second.getScore())
			return 1;
		else if (getScore() < second.getScore())
			return -1;
		
		return 0;
	}

protected int getScore()
	{
		return score;
	}

protected int getId()
    {
        return id;
    }
    

There is code already which u can use instead of code something that u saw in ur sleep or something

 

Since i dont code things in l2j,i will try to make it as simple as i can tho (what i would do):

If its supposed to be more than X teams (x >>2):

Track down the team with the highest score.Since i dont know what kind of collection is this,dunno whats more efficient(dunno the methods but it looks like hashmap or what...arraylist fanboy).

Copy the team with the highest score into an object,and later on get the id.That might be the most easy way.

OR 

set highestScore=0 id =0,compare score that each team's score and if it has higher score than that,save the id and after the loop return it.

If its supposed to be with 2 teams:

Just get their scores and return the id.

 

Thats my prespective.No coding in l2j tho Kappa

 

- Editted several times to clarify how u can actually code it-

gl

 

P.S thats w/o 2 team same score.if 2 teams have same score,it becomes more tricky.

 

What you mean more tricky ?

 

If team 1 and team 2 has same score it will return 0 anyway 

  • 0
Posted
protected int getWinnerTeam()
{
	final EventTeam team = teams.values().stream().sorted(Comparator.comparing(EventTeam::getScore).reversed()).findFirst().orElse(null);
	return team == null ? 0 : team.getId();
}

Exact same broken getWinnerTeam logic to java.

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now



  • Posts

    • L2GOLD - Gold x45 C4 Project   C4 - Scions of Destiny: Protocol 656   Fully L2Gold Features - Daily Quest - Daily Mining Quest - Ancient Weapons -Refine System  -Rebirth System -Fully configurable everything you want -Gold stats/Gold skills/Gold items working 100% -Zones 100% alike  -Unique donations system (npc or voicedcommand .donate) - On Enchant success announcement ( if +16 for weapon, 8 for armor , 7 for jewel) - Announce of Castle Lord - Announce of Hero  - Olympiad Max A grade - Olympiad Buffs on matches changed to Gold Alike -Buff shop system on selling buffs with command .buffshop Shift+click dropinfo on mobs. and many more ingame addons.   Server is running a Test Server: Online to anyone can test it.   Game Client: https://www.mediafire.com/file/d0000rmt8ym0323/Lineage_2_C4_Client.rar/file   Game Patch: https://www.mediafire.com/file/39sojdex2mgj55k/L2Gold+Patch+C4.rar/file   GM Accounts: ID: root1 pass root1 [ accounts go from  root1 until root20 ]   Regular Accounts Registrations: http://84.247.164.27/?page=register   Some Screenshots: https://imgur.com/a/KSE4kdq   Contact me here via PM (only serious buyers).    Price of the product: Fully Server Pack + Source ( 200 Euros )
    • Https://lineage2dex.com Discord link : https://discord.com/channels/786506979493281794/814778540893536307/1424434670690504874 ## Dexters! **Our x25 server is celebrating its first week!** 🔥 Online stays strong at peak levels!  New players are joining every day, with 200+ new master accounts registered daily — amazing results! ✨ Tomorrow we launch a new episode along with the first event. Full details will be shared in the morning(October 6). 🎁 And for this little celebration, here’s a bonus code with a small gift for you! ## O05-IIW **Contains: ** * x3 - Training Potion 200% (20 min) * x200 - Mana Potions Loyatly (no weight) *The code will remain active until October 6, 7 AM(server time). And be sure, you have at less 20 slots free on inv before using a code.* **👉 How to redeem:** 1. Log in to your Master Account on site. 2. Click the Redeem Bonus Code button at the top of the panel, type code click redeem. 3. Select the account and character you want to receive the gift.  **Codes work only 1 time for 1 Master Account!** ### Enjoy your adventure, Dexters!
    • Complete Server Pack + Source Files:     C4 Scions Of Destiny: P656 Retail X1 L2OFF Server Pack + Source: Price: 70 EUR   C4 Scions Of Destiny: P656 ESL2 Athena x45 L2OFF Server Pack + Source: Price: 90 EUR Screenshots: https://imgur.com/a/eternal-sin-l2-athena-x45-c4-WYCpbjl   C6 Interlude: P746 ESL2 Athena x45 L2OFF Server Pack + Source: Price: 100EUR The same as C4 but in C6 Client so the Screenshots is the same: https://imgur.com/a/eternal-sin-l2-athena-x45-c4-WYCpbjl     C6 Interlude: P746 L2Gold L2OFF Server Pack + Source: Price: 50EUR Screenshots: https://imgur.com/a/9kB3oA9   C6 - Classic Interlude: P110 ESL2 Athena x45 L2OFF Server Pack + Source: Price: 100EUR Screenshots: https://imgur.com/a/Z2kZxuv   Contact me here via PM (only serious buyers). 
    • Where should I modify the IP to be able to put it online for testing?
    • I had issues with Smart Guard to, there is not even support in many cases.
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock