Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5 introduce Dynamic Multi Frame Generation e MFG 6X, permettendo fino a cinque frame generati per ogni frame renderizzato. I test su Cyberpunk 2077 e 007 First Light mostrano forti incrementi di FPS e riduzione della latenza su RTX 5090 Laptop. Migliorano fluidità, stabilità e qualità visiva.
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-06-2010, 08:53   #1
doricum
Junior Member
 
Iscritto dal: May 2010
Messaggi: 4
[java] info su controllo matrice

Ciao,
ho un problema, in una matrice ho memorizzato dei valori interi compresi in un range tra 0 e 2. devo riuscire a controllare in tutta la matrice sia orizzontale, verticale che in diagonale se esistono ad esempio una terna di 1 o di 2.
ma non solo , se esiste una terna e subito prima o subito dopo c'è uno 0 allora mi restituisce la posizione dello 0 ; ad esempio :
001112112 -> return 2 oppure 0021110221 -> return 7

qualcuno sa darmi un suggerimento su come poter implementare un algoritmo o se esiste qualcosa di simile in giro ?

grazie mille
doricum è offline   Rispondi citando il messaggio o parte di esso
Old 20-06-2010, 08:42   #2
Mixmar
Senior Member
 
L'Avatar di Mixmar
 
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 962
La prima idea che mi viene in mente è quella di ridurre la matrice ad un insieme di "stringhe-vettori", e poi di utilizzare le funzioni di ricerca delle stringhe per trovare le terne e gli zeri.

Per esempio, potresti trasformare tutte le righe in stringhe, ottenendo un array di stringhe in cui ogni carattere è una cifra, e poi effettuare una ricerca del tipo:

Codice:
posizioneTerna1 = "001112112...".indexOf("111");
per trovare la prima terna di "1", poi controlli se i caratteri precedente seguenti sono zero, con ".substring()". Quindi, procedi nella stringa-vettore cercando la prossima occorrenza dellla stessa terna fino a finire la stringa (se non ricordo male, basta passare un parametro in più ad indexOf, così:

Codice:
posizioneTerna2 = "001112112...".indexOf("111", posizioneTerna1)
Dovresti iterare su ogni terna che cerchi, per ogni stringa-vettore.

Poi ripeti tutto, questa volta trasformando le colonne in stringhe.

Infine, ripeti il procedimento per l'ultima volta sulle diagonali (tra parentesi, non ho capito se ti interessino solo le diagonali principali o anche le altre).

Questo metodo non è computazionalmente molto efficiente (troppe conversioni a stringa / ricerche): penso che si possa fare di meglio, visti gli stretti limiti matematici del problema (l'insieme dei possibili valori assunti dalle celle della matrice è limitato, ricerchi una sequenza regolare...). Purtroppo, non saprei come creare un metodo più efficiente sfruttando la matematica: provaci tu, serve ingegnosità e un ripasso dell'algebra delle matrici.
__________________
"Et Eärallo Endorenna utúlien. Sinome maruvan ar Hildinyar tenn' Ambar-metta!" -- Aragorn Elessar, Heir of Isildur
Mixmar -- OpenSuSE 11.1 on AMD 64 3000+ on DFI LanParty nF4-D | GeForce 6600 GT + Thermaltake Schooner on Samsung 710N
Storage -- ( 2 x Hitachi Deskstar 80 Gb + 1 x Hitachi 250 Gb ) = 1 RAID 5 + 1 Storage space LaCie Ethernet Disk Mini 250 Gb | HP - DV2150 EL MILAN CLAN
Mixmar è offline   Rispondi citando il messaggio o parte di esso
Old 20-06-2010, 10:17   #3
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Oppure iteri su tutti gli elementi e consideri di volta in volta il quadratino 9x9
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 20-06-2010, 10:37   #4
doricum
Junior Member
 
Iscritto dal: May 2010
Messaggi: 4
Grazie mille per il vostro prezioso aiuto!
il controllo devo farlo su tutte le diagonali e forse la gestione diventa un pò più complicata.

Ultima modifica di doricum : 20-06-2010 alle 10:40.
doricum è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 17:04   #5
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da doricum Guarda i messaggi
Grazie mille per il vostro prezioso aiuto!
il controllo devo farlo su tutte le diagonali e forse la gestione diventa un pò più complicata.
Prendendo spunto da un esempio di classe per gestire una matrice che avevo postato in un vechcio thread ed aggiungendo solo lo stretto neccessario (pigrizia & fretta rules!) sono giunto a questo:

Una classe di routine, per rappresentare un singolo "match"
Codice:
package matrix;

/**
 *
 * @author francesco
 */
public class Match
{
    private final int ROW, COLUMN;
    private final String TYPE;
    private final Matrix REF;

    public Match(int row, int col, String type, Matrix mat) {
        ROW = row;
        COLUMN = col;
        TYPE = type;
        REF = mat;
    }

    public int getROW() {
        return ROW;
    }

    public int getCOLUMN() {
        return COLUMN;
    }

    public String getTYPE() {
        return TYPE;
    }

    public Matrix getMATRIX() {
        return REF;
    }

    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder();
        sb.append("@[").append(ROW).append("][").append(COLUMN).append("]->").append(TYPE)
          .append("=").append(REF.getValueAt(ROW, COLUMN));
        return sb.toString();
    }
}
La classe matrice. Nel main c'è un esempio di utilizzo.
Codice:
package matrix;

import java.util.ArrayList;
import java.util.List;

/**
 *
 * @author francesco
 */
public class Matrix
{
    private final int ROWS, COLUMNS;
    private boolean initialized;
    private final int[][]DATA;

    public Matrix(int r, int c) {
        if (r<1 || c<1)
            throw new IllegalArgumentException("Il valore di righe e colunne deve essere maggiore di zero.");
        
        ROWS = r;
        COLUMNS = c;
        DATA = new int[ROWS][COLUMNS];
    }

    public Matrix(int data[][]) {
        if (data==null || data.length<1 || data[0].length<1)
            throw new IllegalArgumentException("Impossibile costruire una matrice di zero righe o " +
                    "zero colonne.");

        ROWS = data.length;
        COLUMNS = data[0].length;
        DATA = new int[ROWS][COLUMNS];
        initData(data);
    }

    /** torna una copia dei dati nella matrice */
    public int[][] getData() {
        int[][] copyData = new int[ROWS][COLUMNS];
        for (int r=0; r<ROWS; r++)
            for (int c=0; c<COLUMNS; c++) copyData[r][c] = DATA[r][c];
        return copyData;
    }

    /** inizializza la matrice */
    public void initData(int newdata[][]) {
        if (initialized)
            throw new RuntimeException("Impossibile modificare la matrice");

        initialized = true;
        for (int r=0; r<ROWS; r++)
            for (int c=0; c<COLUMNS; c++) DATA[r][c] = newdata[r][c];
    }

    public int getValueAt(int row, int column) {
        if (!isRowValid(row) || !isColumnValid(column))
            throw new IllegalArgumentException("Valore di riga o di colonna fuori dal range valido");

        return DATA[row][column];
    }

    private boolean isRowValid(int row) {
        return  row>=0 && row<ROWS;
    }

    private boolean isColumnValid(int column) {
        return  column>=0 && column<COLUMNS;
    }

    /** ottieni la matrice trasposta di questa matrice */
    public Matrix getTrasposta() {
        Matrix tras = new Matrix(COLUMNS, ROWS);
        for (int c=0; c<COLUMNS; c++)
            for (int r=0; r<ROWS; r++) tras.DATA[c][r] = DATA[r][c];
        return tras;
    }

    /** 
     * Ottieni tutti i match nelle righe del pattern rappresentato dal valore V ripetuto per N volte.
     * Gli elementi di una riga N sono indirizzati da ogni [N][c] valido, con c -> 0, c+1, ...
     */
    public List<Match> findRowsMatch(final int V, final int N) {
        List<Match> matches = new ArrayList<Match>();
        for (int r=0; r<ROWS; r++) {
            int count = 0;
            for (int c=0; c<COLUMNS; c++) {
                int elem = DATA[r][c];

                if (elem == V)
                    count++; 
                else
                    count = 0;

                if (count == N) {
                    Match m = new Match(r, c-(N-1), "Hor", this);
                    matches.add(m);
                    count = 0;
                }
            }
        }
        return matches;
    }

    /**
     * Ottieni tutti i match nelle colonne del pattern rappresentato dal valore V ripetuto per N volte.
     * Gli elementi di una colonna N sono indirizzati da ogni [r][N] valido, con r -> 0, r+1, ...
     */
     public List<Match> findColumnsMatch(final int V, final int N) {
        List<Match> matches = new ArrayList<Match>();
        for (int c=0; c<COLUMNS; c++) {

            int count = 0;
            for (int r=0; r<ROWS; r++) {
                int elem = DATA[r][c];

                if (elem == V)
                    count++;
                else
                    count = 0;

                if (count == N) {
                    Match m = new Match(r-(N-1), c, "Col", this);
                    matches.add(m);
                    count = 0;
                }
            }

        }
        return matches;
     }

    /**
     * Ottieni tutti i match nelle diagonali del pattern rappresentato dal valore V ripetuto per N volte.
     * Le diagonali vengono controllate rispetto alla regione NxN riferita ad un elemento [er][ec] e definita
     * a sua volta come la matrice NxN degli [er+N-1][ec+N-1] elementi.
     */
    public List<Match> findDiagonalMatch(final int V, final int N) {
        List<Match> matches = new ArrayList<Match>();
        for (int r=0; r<ROWS; r++) {
            for (int c=0; c<COLUMNS; c++) {
                // get the square sub-matrix (region)
                Matrix region = getRegionFrom(r,c,N);
                if (region == null)
                continue;
                // check first diagonal
                for (int count=0, i=0; i<N; i++) {
                    int elem = region.getValueAt(i,i);
                    if (elem == V)
                        count++;
                    else
                        count = 0;
                    if (count == N) {
                        Match m = new Match(r, c, "Diag1", this);
                        matches.add(m);
                        count = 0;
                    }
                }
                // check second diagonal
                for (int count=0, rr=N-1, rc=0;  rc<N;  rr--, rc++) {
                    int elem = region.getValueAt(rr,rc);
                    if (elem == V)
                        count++;
                    else
                        count = 0;
                    if (count == N) {
                        Match m = new Match(r, c+(N-1), "Diag2", this);
                        matches.add(m);
                        count = 0;
                    }
                }
            }
        }
        return matches;
    }
    
    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder();
        for (int r=0; r<ROWS; r++) {
            for (int c=0; c<COLUMNS; c++) sb.append(DATA[r][c]).append(".");
            sb.append("\n");
        }
        return sb.toString();
    }

    /** Return the sub-matrix of NxN elements starting from element[r][c] if possible, otherwise null*/
    public Matrix getRegionFrom(int r, int c, int N) {
        if (isRowValid(r+N-1) && isColumnValid(c+N-1)) {
            int[][] data = new int[N][N];
            for (int newR=0, oldR=r;  oldR<r+N;  newR++, oldR++)
                for (int newC=0, oldC=c;  oldC<c+N;  newC++, oldC++)
                    data[newR][newC] = DATA[oldR][oldC];
            return new Matrix(data);
        }
        else
            return null;
    }


    // TEST
    public static void main(String... argv) {
        int[][]data = { {1,1,1,0,0,0,0,0,2,2,2,0,0,0,0,0},
                        {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
                        {0,0,0,0,2,2,2,0,0,0,0,0,0,0,0,0},
                        {0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0},
                        {0,0,0,0,0,1,1,0,0,2,0,0,0,0,0,0},
                        {0,0,0,0,0,1,0,0,0,0,2,0,0,1,1,1},
                        {0,0,0,0,1,0,0,0,0,0,0,2,0,0,1,1},
                        {0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1}, };
        Matrix m = new Matrix(data);
        System.out.println("matrice originale:\n"+m);
        //System.out.println("matrice trasposta:\n"+m.getTrasposta());
        int value, count;
        List<Match> matches;

        value = 2;
        count = 3;
        matches = m.findRowsMatch(value, count);
        for (Match mt : matches)
            System.out.println(mt);

        value = 1;
        count = 3;
        matches = m.findColumnsMatch(value, count);
        for (Match mt : matches)
            System.out.println(mt);

        value = 1;
        count = 3;
        matches = m.findDiagonalMatch(value, count);
        for (Match mt : matches)
            System.out.println(mt);
    }
}
Dovrebbe stampare:
Codice:
matrice originale:
1.1.1.0.0.0.0.0.2.2.2.0.0.0.0.0.
0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.
0.0.0.0.2.2.2.0.0.0.0.0.0.0.0.0.
0.0.0.0.0.1.0.0.0.0.0.0.0.0.0.0.
0.0.0.0.0.1.1.0.0.2.0.0.0.0.0.0.
0.0.0.0.0.1.0.0.0.0.2.0.0.1.1.1.
0.0.0.0.1.0.0.0.0.0.0.2.0.0.1.1.
0.0.0.0.0.0.0.0.0.0.0.0.0.1.0.1.

@[0][8]->Hor=2
@[2][4]->Hor=2
@[3][5]->Col=1
@[5][15]->Col=1
@[4][6]->Diag2=1
@[5][13]->Diag1=1
@[5][15]->Diag2=1
Fa molto schifo ma funziona.
(Rifattorizzare e pulire sarebbe d'obbligo, ma ho scritto + o - al volo e questo ho partorito ):
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 21-06-2010 alle 17:08.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
SpaceX Starfall, capsule per lo sviluppo...
Fable 5, il modello Mythos per tutti: gr...
Costruire sulla Luna: i test per le futu...
La NASA ha annunciato gli astronauti del...
Mondiale 2026, Lenovo unico partner tecn...
007 First Light ha venduto più di...
Harley-Davidson, svelato il prezzo itali...
PC Windows 11 in crash: ma la colpa è di...
Dopo i 'NO 5G' arrivano i 'NO FIBRA'? Ar...
Promettono un parco e costruiscono un da...
L'aeroplano supersonico ''silenzioso'' N...
Euro-Office sbugiardata da LibreOffice: ...
I 10 sconti TOP Amazon: 4 novità ...
Galaxy Z Flip 8, in Europa avrà i...
SpaceX annuncia i satelliti AI1 destinat...
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: 20:20.


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