Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Amazon porta i colori sul suo Kindle da scrittura più grande: schermo Colorsoft a 11 pollici, processore quad-core, penna premium più reattiva e strumenti IA per le note, sono le note salienti. Il salto di prezzo rispetto al modello in bianco e nero si fa sentire, anche se la percezione è quella di trovarsi di fronte a un prodotto di fascia altissima, per veri appassionati
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-07-2008, 15:15   #1
moka
Senior Member
 
L'Avatar di moka
 
Iscritto dal: Jan 2005
Messaggi: 3577
[Java][LinkedList]

devo fare un esercizio in preparazione di un esame universitario, ma non riesco a uscirne fuori qualcuno saprebbe aiutarmi?
la cosa da cui proprio non riesco a cavarmi fuori è come fare a puntare ciclicamente all' elemento next, dovendo passare per head è una cosa difficile da spiegare copio l'esercizio faccio prima

questa è la classe:

public class ListLinked {
private Node head;

private class Node {
private String content;
private Node next;

public Node(String c, Node n) {
content = c;
next = n;
}

public Node(String c) { this(c, null); }
}

public ListLinked() {
head = null;
}

public boolean isEmpty() { return head == null; }

public void addToStart(String s) {
Node newNode = new Node(s, head);
head = newNode;
}

public static ListLinked cons(String c, ListLinked l) {
ListLinked result = new ListLinked();
result.addToStart(c);
if (l != null) result.head.next = l.head;
return result;
}

public String first() { return isEmpty() ? null : head.content; }

public ListLinked rest() {
if (isEmpty()) {
return null;
}
else {
ListLinked result = new ListLinked();
result.head = head.next;
return result;
}
}

public ListLinked concatenate(ListLinked l) {
if (isEmpty()) {
return l;
}
else {
return cons(first(), rest().concatenate(l));
}
}

public int printLength = 5;
public int setPrintLength(int pl) { return printLength = pl; }
public int getPrintLength() { return printLength; }

public String toString() {
String result;

if (isEmpty()) {
return "()";
}
else {
int i;
Node n;

result = "(" + head.content;
for (n = head.next, i = 1;
n != null || (printLength > 0 && i > printLength);
n = n.next, i++) {
result += " " + n.content;
}

if (printLength > 0 && i > printLength) result += "...";
result += ")";
return result;
}
}



public static void main(String[] args) {
ListLinked l = cons("A", cons("B", cons("C", null)));

System.out.println(l);
}
}

questi i metodi da implementare:

public ListLinked reverse(); // Inverte una lista
public ListLinked remove(String s); // Crea una nuova lista con 's' rimosso.
public ListLinked oddList(); // Crea una nuova lista con solo gli elementi in posizione dispari.
public ListLinked evenList(); // Crea una nuova lista con solo gli elementi in posizione pari.
public int length(); // Riscrivere *senza* usare cicli; potete fare un overload.

mi basta che me ne venga risolto / spiegato uno fra questi, poi dopo per gli altri ci penso io grazie per la pazienza
__________________
L'EMPOLI NON SI DISCUTE... SI AMA
moka è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2008, 18:24   #2
moka
Senior Member
 
L'Avatar di moka
 
Iscritto dal: Jan 2005
Messaggi: 3577
in particolare il mio problema sta nel poter richiamare ciclicamente l'attributo next che è un oggetto della classe stessta, la quale è un attributo della altra classe.

tanto per farmi capire, a parole è difficile:
(mi scuso per la qualità delle immagini )


dunque, mettiamo caso che io devo trovare il nodo che nell'attributo di tipo stringa val ha valore "ciao", e poi stampare a video il contenuto del nodo successivo(next), come posso fare?
__________________
L'EMPOLI NON SI DISCUTE... SI AMA
moka è offline   Rispondi citando il messaggio o parte di esso
Old 10-07-2008, 15:03   #3
moka
Senior Member
 
L'Avatar di moka
 
Iscritto dal: Jan 2005
Messaggi: 3577
Quote:
Originariamente inviato da moka Guarda i messaggi
public ListLinked reverse(); // Inverte una lista
Codice:
public ListLinked reverse(){
    	ListLinked k=new ListLinked();
    	Node n=new Node(null, head);
    	Vector<Node>v=new Vector<Node>(1);
    	if(head==null){
    		System.out.println("la lista è vuota!");
    	}else{
    		while(n.next!=null){
    			v.add(n.next);
    			v.setSize(v.size()+1);
    			n=n.next;
    		}
    		Node[]q=new Node[v.size()];
    		for(int i=0;i<v.size();i++){
    			q[i]=v.get(v.size()-i-1);
    		}
    		for(int i=0;i<v.size();i++){
    			q[i].next=q[i+1];
    		}
    		k.head=q[0];
    	}
    	return k;
    	
    }
mi da errore sul finale
__________________
L'EMPOLI NON SI DISCUTE... SI AMA
moka è offline   Rispondi citando il messaggio o parte di esso
Old 10-07-2008, 16:51   #4
Oceans11
Senior Member
 
L'Avatar di Oceans11
 
Iscritto dal: Sep 2005
Città: Torino
Messaggi: 606
Quote:
dunque, mettiamo caso che io devo trovare il nodo che nell'attributo di tipo stringa val ha valore "ciao", e poi stampare a video il contenuto del nodo successivo(next), come posso fare?
devi scandire la lista fino a che non trovi il nodo in questione...

Codice:
Node aux = head;
while(aux != null && !aux.val.equals("ciao") {
   aux = aux.next;
}
if(aux != null && aux.next != null) {
      System.out.println(aux.val);
}
il ciclo while dice: avanzo nella lista fino a che non sto puntando ad un elemento Node nullo oppure l'elemento attuale ha il campo val uguale a "ciao".
Terminato il while ho 2 possibilità:
1) ho scorso tutta la lista e quindi non ho trovato nessun elemento il cui campo val è "ciao" (quindi aux = null)
2) ho trovato l'elemento il cui campo val è "ciao" e quindi aux punta a quello.

in questo secondo caso allora devo controllare se l'elemento successivo ad aux è null, in caso contrario stampo il suo val.

NB: tutti i controlli rispetto a null si devono fare altrimenti viene lanciata una NullPointerExceptio a runtime.

NMB: non ci metto la mano sul fuoco....tra l'altro sono senza compilatore e non posso provare.
__________________
"Se proprio dovete piratare un prodotto, preferiamo che sia il nostro piuttosto che quello di qualcun altro." [Jeff Raikes]
"Pirating software? Choose Microsoft!"
Oceans11 è offline   Rispondi citando il messaggio o parte di esso
Old 10-07-2008, 18:20   #5
moka
Senior Member
 
L'Avatar di moka
 
Iscritto dal: Jan 2005
Messaggi: 3577
Quote:
Originariamente inviato da Oceans11 Guarda i messaggi
devi scandire la lista fino a che non trovi il nodo in questione...

Codice:
Node aux = head;
while(aux != null && !aux.val.equals("ciao") {
   aux = aux.next;
}
if(aux != null && aux.next != null) {
      System.out.println(aux.val);
}
il ciclo while dice: avanzo nella lista fino a che non sto puntando ad un elemento Node nullo oppure l'elemento attuale ha il campo val uguale a "ciao".
Terminato il while ho 2 possibilità:
1) ho scorso tutta la lista e quindi non ho trovato nessun elemento il cui campo val è "ciao" (quindi aux = null)
2) ho trovato l'elemento il cui campo val è "ciao" e quindi aux punta a quello.

in questo secondo caso allora devo controllare se l'elemento successivo ad aux è null, in caso contrario stampo il suo val.

NB: tutti i controlli rispetto a null si devono fare altrimenti viene lanciata una NullPointerExceptio a runtime.

NMB: non ci metto la mano sul fuoco....tra l'altro sono senza compilatore e non posso provare.
non ti preoccupare, è tutto giusto quello che dici!
MA questo esercizio l'avevo da poco capito anche io...
ho dubbi sul reverse, per esempio, ma secondo te se riesco a farlo con i Vector, funziona la cosa? è giusta?
__________________
L'EMPOLI NON SI DISCUTE... SI AMA
moka è offline   Rispondi citando il messaggio o parte di esso
Old 10-07-2008, 22:32   #6
moka
Senior Member
 
L'Avatar di moka
 
Iscritto dal: Jan 2005
Messaggi: 3577
che mi dite di iterator?
__________________
L'EMPOLI NON SI DISCUTE... SI AMA
moka è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2008, 07:00   #7
Oceans11
Senior Member
 
L'Avatar di Oceans11
 
Iscritto dal: Sep 2005
Città: Torino
Messaggi: 606
mi deve essere sfuggita qualche cosa allora....!


cmq per il reverse stavo pensando a semplici inserimenti e rimozioni. Mi spiego meglio.

Non è necessario l'utilizzo di una struttura dati ausiliaria. Si può benissimo prendere il elemento della prima lista, rimuoverlo dalla prima ed inserirlo in testa ad una seconda (etc...), che è poi quella che devi restituire, no?
__________________
"Se proprio dovete piratare un prodotto, preferiamo che sia il nostro piuttosto che quello di qualcun altro." [Jeff Raikes]
"Pirating software? Choose Microsoft!"
Oceans11 è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2008, 14:34   #8
Lukas17
Member
 
L'Avatar di Lukas17
 
Iscritto dal: Nov 2006
Città: Monza
Messaggi: 70
Se ti serve ancora questo è il metodo Reverse funzionante:


public ListLinked reverse(){ // inverte una lista
Node curr = head;
if(curr == null) throw new NoSuchElementException();
if(curr.next == null) {return null;}
Node temp = null;
while (curr != null) {
Node next = curr.next;
curr.next = temp;
temp = curr;
curr = next;
}
head = temp;
return null;
}
__________________
Lµкє ™
Lukas17 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
Meta Brain2Qwerty v2: l'IA che trasforma...
Windows 11 può funzionare su...
Sicurezza dei minori sui social: su 86 s...
Google avrebbe limitato l'accesso di Met...
Qwen 3.6 27B apre una nuova era per l'IA...
Dyson V8 Absolute a 299€ su Amazon: la s...
Le migliori offerte sugli smartphone su ...
Amazon spiega le ragioni del passaggio d...
ECOVACS DEEBOT MINI scende ancora di pre...
Colpo di scena: NVIDIA PhysX gira su GPU...
Samsung non accelera, il processo a 1,4 ...
Abbiamo provato la DJI Osmo Pocket 4P a ...
Koei Tecmo annuncia un nuovo action chia...
La postazione racing di Kimi Antonelli c...
Amazon TOP 10: rivoluzione nelle prime 4...
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: 12:30.


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