Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Questo mouse ultraleggero, con soli 36 grammi di peso, è stato concepito per offrire un'esperienza di gioco di alto livello ai professionisti degli FPS, grazie al polling rate a 8.000 Hz e a un sensore ottico da 33.000 DPI. La recensione esplora ogni dettaglio di questo dispositivo di gioco, dalla sua agilità estrema alle specifiche tecniche che lo pongono un passo avanti
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni
Dal richiamo di Enrico Letta alla necessità di completare il mercato unico entro il 2028 alla visione di Nokia sul ruolo dell’IA e delle reti intelligenti, il Nokia Innovation Day 2025 ha intrecciato geopolitica e tecnologia, mostrando a Vimercate come la ricerca italiana contribuisca alle sfide globali delle telecomunicazioni
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
OPPO Reno14 F 5G si propone come smartphone di fascia media con caratteristiche equilibrate. Il device monta processore Qualcomm Snapdragon 6 Gen 1, display AMOLED da 6,57 pollici a 120Hz, tripla fotocamera posteriore con sensore principale da 50MP e generosa batteria da 6000mAh con ricarica rapida a 45W. Si posiziona come alternativa accessibile nella gamma Reno14, proponendo un design curato e tutto quello che serve per un uso senza troppe preoccupazioni.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-11-2007, 21:59   #1
erkk84
Member
 
Iscritto dal: Dec 2006
Messaggi: 53
[Java] ordinamento classifica calcio

Ciao a tutti, devo fare un programmino che dato in input una cosa del genere:

4
Brazil
Norway
Morocco
Scotland
6
Brazil#2@1#Scotland
Norway#2@2#Morocco
Scotland#1@1#Norway
Brazil#3@0#Morocco
Morocco#3@0#Scotland
Brazil#1@2#Norway

dopo apposito parsing, mi dà in output una cosa del genere:

1) Brazil 6p, 3g (2-0-1), 3gd (6-3)
2) Norway 5p, 3g (1-2-0), 1gd (5-4)
3) Morocco 4p, 3g (1-1-1), 0gd (5-5)
4) Scotland 1p, 3g (0-1-2), -4gd (2-6)


Quindi ordinata per punteggio, in caso di parità per partite vinte, in caso per differenza goal.
Io ho scritto una cosa così per il momento:
Codice:
class Squadra implements Comparable<Squadra>{
    
    private String name;
    private int score;
    
    public Squadra(String name) {
        this.name = name;
        score= 0;
    }
    
    public String getName() {return name;}
    public int getScore() {return score;}
    public void setScore(int score) {this.score=score;}
    
    //Si mette il vincolo che ogni squadra abbia nome univoco.
    public int hashCode() {return name.hashCode();}
    public boolean equals(Object obj) {
        if(obj instanceof Squadra)
            return ((Squadra)obj).getName().equals(name);
        return false;
    }
    public String toString(){
        return name+" "+score+"p";
    }
    public int compareTo(Squadra s) {
        if(name.equals(s.getName()))
            return 0;
        int result = score-s.getScore();
        if(result==0)
            result = name.compareTo(s.getName());
        return result;
    }
}

 class Classifica {
    
    public HashMap map;
    public ArrayList squadre;
    
    
    public Classifica() {
        map  = new HashMap();
        squadre = new ArrayList();
    }
    
    public boolean add(String name) {
        if(map.containsKey(name)) {
            return false;
        }
        
        Squadra s = new Squadra(name);
        map.put(name, s);
        squadre.add(s);  
        return true;         
    }
    
    public boolean remove(String name) {
        if(!map.containsKey(name)) {
            return false;
        }
        Squadra s = (Squadra) map.remove(name);
        squadre.remove(s);
        return true;
    }
    
    public boolean addPoint(String name, int point) {
        if(!map.containsKey(name)) {
            return false;
        }
        Squadra s = (Squadra)map.get(name);
        s.setScore(s.getScore()+point);
        return true;
    }
    
    public int getScore(String name){
        Squadra s = (Squadra)map.get(name);
        return (s.getScore());        
    }
    
    public static void main(String args[]) {
        
        BufferedReader input;
        String in2,in3,in4,in5;
     
   Classifica clas = new Classifica();
                   
         try {
             System.out.println("Dammi il numero delle squadre: ");
        
             input = new BufferedReader(new InputStreamReader(System.in)); 
             
             in2 = input.readLine();
      
             System.out.println("Dammi i nomi delle squadre: ");
             
             for (int i=0;i<Integer.valueOf(in2);i++) {
             
                 in3 = input.readLine();
                 clas.add(in3);
            }
             
             System.out.println("Dammi il numero degli incontri: "); 
            
            in4 = input.readLine();
            
            System.out.println("Dammi gli incontri: ");
            
            for (int i=0;i<Integer.valueOf(in4);i++) {
                
                in5 = input.readLine();
                
                int g1 = in5.indexOf("#")+1;
                int g2 = in5.indexOf("@")+1;
                
              String goal1 = in5.substring(g1,g1+1);
              String goal2 = in5.substring(g2,g2+1);
                      
              if (Integer.valueOf(goal1)>Integer.valueOf(goal2)) {
                  clas.addPoint(in5.substring(0,g1-1),3); 
                  clas.addPoint(in5.substring(g2+2,in5.length()),0);
                }
              
              if (Integer.valueOf(goal1)<Integer.valueOf(goal2)) {
                  clas.addPoint(in5.substring(0,g1-1),0); 
                  clas.addPoint(in5.substring(g2+2,in5.length()),3);
                }
              
              if (Integer.valueOf(goal1)==Integer.valueOf(goal2)) {
                  clas.addPoint(in5.substring(0,g1-1),0); 
                  clas.addPoint(in5.substring(g2+2,in5.length()),0);
                    }
            }
         } catch (Exception ex) { }
    }
}
Praticamente mi sono bloccato sull'ordinamento;come faccio a ordinarli nella maniera sopraindicata?se poteste spiegarmi con del codice sarebbe ancora meglio..so che con le hashmap è impossibile fare un ordinamento epr valori, perciò bisognerebeb tirare fuori i valori in un'altra struttura e ordinare da li...ecco, a parole ho capito cosa bisogna fare ma non so da dove partire col codice..

garzie mille a tutti..ciao
erkk84 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza Sottile, leggero e dall'autonomia WOW: OPPO Reno...
Destiny Rising: quando un gioco mobile supera il gioco originale Destiny Rising: quando un gioco mobile supera il...
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
Adesso ci si può laureare in stor...
Impact.com ridefinisce il performance ma...
Nintendo non considera le mod dannose pe...
Dreame inaugura il suo flagship store a ...
OpenAI e Jony Ive: in arrivo un disposit...
TikTok, secondo Trump l'accordo con Xi &...
HUAWEI, tutte le novità dell'even...
Mercedes GenH2 Truck sulle Alpi: oltre 1...
Shadow Leak: ecco come ChatGPT poteva es...
Google Gemini 2.5 batte quasi tutti gli ...
Battlefield 6: i giocatori console non p...
Iliad rinnova l'offerta mobile: tre pian...
HUAWEI Watch GT 6 ufficiale: design al t...
Reggie Townsend di SAS: l’etica dell’IA ...
Startup Marathon in vista del traguardo:...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 02:18.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v