• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Java - usuwanie powtarzających się liczb w ArrayList

Object Storage Arubacloud
0 głosów
4,364 wizyt
pytanie zadane 21 marca 2016 w Java przez Aisekai Nałogowiec (42,190 p.)

Jak w temacie.

 

public void usunPowtorzenia()
	{
		for(int x : liczby)
		{
			while(liczby.lastIndexOf(x)!=liczby.indexOf(x))
			{
				liczby.remove(x);
			}
		}
		
	}

liczby - ArrayList<Integer>

Chodziło mi o to, żeby do czasu kiedy pierwszy index arraylisty w którym na którym znajdowała się liczba był różny od ostatniego, usuwał ten pierwszy. I takby lista się zmniejszała się za każdym razem, kiedy element by się powtórzył. 

Exception in thread "main" java.util.ConcurrentModificationException - Taki błąd dostałem.

2 odpowiedzi

0 głosów
odpowiedź 21 marca 2016 przez Mar Cin Dyskutant (8,900 p.)

Chodzi Ci o to że gdy w liście np. występują powtórzenia liczb:

lista={1,1,2,4,5,5,2};

usuwasz powtórzenia i zwracasz liste:

lista={1,2,4,5};

Jeżeli dobrze Cię rozumiem to ja zrobiłbym to w ten sposób mniej więcej:

	public void usunPowtorzenia(){
	
	for(int i=0;i<getRozmiar(); i++){
		
		for(int j=1; j<getRozmiar(); j++){
			
			if(i!=j && lista.get(i)==lista.get(j)){
				
				lista.remove(j);
				setRozmiar(lista.size());
			}
			
		}
	}
		
	}

 

komentarz 21 marca 2016 przez Aisekai Nałogowiec (42,190 p.)
A czy to nie jest prawdą, że nie można usunąć elementu z środka? Tak mi na 4programmers napisali
0 głosów
odpowiedź 21 marca 2016 przez Porcupine Nałogowiec (31,560 p.)
Jeśli nie zależy Ci na zachowaniu kolejności elementów to prawdopodobnie najkorzystniejszym rozwiązaniem będzie posortowanie tablicy, a następnie przejście jej raz od lewej do prawej w prosty sposób usuwając powtórzenia liczb, które są obok siebie. To da złożność czasową: O( n log n) przy stałej złożoności pamięciowej.

Podobne pytania

+1 głos
1 odpowiedź 557 wizyt
+1 głos
2 odpowiedzi 384 wizyt
0 głosów
1 odpowiedź 415 wizyt
pytanie zadane 6 lutego 2019 w Systemy operacyjne, programy przez Paweł Soszyński Początkujący (260 p.)

92,634 zapytań

141,505 odpowiedzi

319,883 komentarzy

62,015 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...