Usunięcie z listy elementu

Usunięcie z listy elementu
K7
  • Rejestracja:ponad 7 lat
  • Ostatnio:ponad 3 lata
  • Postów:98
0

Witam, czy takie rozwiązanie jest poprawne?
Mam listę typu int w której są liczby od 0 do 1000. Chcę aby z tej listy usunięto liczby większe od 100.
Czy poniższe rozwiązanie jest dobre?
załóżmy że lista jest już wypełniona

Kopiuj
List<int> liczby = new List<int>();
foreach(var i in liczby){
if(i>100){
liczby.Remove(i);
}
}
edytowany 1x, ostatnio: kamilm758
grzesiek51114
grzesiek51114
  • Rejestracja:ponad 11 lat
  • Ostatnio:ponad 4 lata
  • Postów:2442
0

A odpalałeś to w ogóle w tej pętli foreach? Sprawdzałeś chociaż czy działa?

Kopiuj
            var list = new List<int> { 1, 2, 3, 4, 5, 3, 4, 5, 6 };
            list.RemoveAll(n => n > 4);
            foreach (var i in list)
            {
                Console.WriteLine(i);
            }
edytowany 2x, ostatnio: grzesiek51114
K7
  • Rejestracja:ponad 7 lat
  • Ostatnio:ponad 3 lata
  • Postów:98
0

właśnie nie działa.
ma ktoś pomysł?

FR
  • Rejestracja:ponad 11 lat
  • Ostatnio:około 7 godzin
  • Postów:948
1

W foreachu nie powinno się usuwać elementów (ani też dodawać), bo modyfikujesz coś na czym się już kręcisz.
Rozwiązanie powyższe jest poprawne (używając linq).
Ewentualnie użyj pętli for do tego

grzesiek51114
grzesiek51114
@froziu: kurcze, nie mogę zaplusować Twojego postu. Dostaję błąd, dziwne.
FR
@grzesiek51114: jakieś błędy forum, mi co chwile pokazuje powiadomienie, mimo że je odczytałem :P
somekind
W rozwiązaniu powyższym nie ma LINQ.
FR
Racja. Używając LINQ także można to przefiltrować :)
JU
No pętla for zadziała podobnie do foreach. Do takich celów używa się while, gdzie sam sterujesz licznikiem.
K7
  • Rejestracja:ponad 7 lat
  • Ostatnio:ponad 3 lata
  • Postów:98
0

a jak to zrobić za pomocą linq?

SA
Przecież w pierwszej odpowiedzi jest RemoveAll. Może jeszcze stałe trzeba podstawić za Ciebie?
K7
  • Rejestracja:ponad 7 lat
  • Ostatnio:ponad 3 lata
  • Postów:98
0

a tak można? po kompilacji niby działa

Kopiuj
for (int i=0; i<liczby.Count; i++) 
            {
                if (liczby[i] > 100)
                {
                    liczby.Remove(liczby[i]);
                    i--;

                }
            }
grzesiek51114
grzesiek51114
  • Rejestracja:ponad 11 lat
  • Ostatnio:ponad 4 lata
  • Postów:2442
0

O_o Przecież dostałeś rozwiązanie na tacy, poza tym jak już jedziesz usuwanie za pomocą for to jedź od końca.

K7
chciałem za pomocą sposobów które rozumiem. a LINQ tak średnio trochę. dzięki za pomoc. nie mogę dać łapki w górę, z powodu jakiegoś błędu na stronce
PA
  • Rejestracja:prawie 8 lat
  • Ostatnio:ponad 2 lata
  • Postów:9
0

a jak to zrobić za pomocą linq?

Kopiuj
var list = new List<int>() { 4, 39, 399, 263, 53, 20 };
list.RemoveAll(x => x > 100);
Sarrus
  • Rejestracja:prawie 14 lat
  • Ostatnio:10 dni
  • Postów:2512
1

Ludzie jakie Linq? RemoveAll jest to metoda klasy List<T>: https://msdn.microsoft.com/en-us/library/wdka673a(v=vs.110).aspx

@kamilm758 masz dobre rozwiązanie. To nie jest rocket science. Wyrażenia lambda są w tej chwili podstawą C# i radzę Ci opanować je jak najszybciej. Zresztą są tak wygodne, że nie wyobrażam sobie życia bez nich :P

edytowany 1x, ostatnio: Sarrus
somekind
Moderator
  • Rejestracja:około 17 lat
  • Ostatnio:7 dni
  • Lokalizacja:Wrocław
2

@Sarrus: no właśnie miałem to napisać. Ludzie myślą, że wszystko co przyjmuje lambdę to LINQ. A tymczasem LINQ jak sama nazwa wskazuje służy do odpytywania, a nie modyfikacji danych.

Rozwiązanie z LINQ:

Kopiuj
var nowaLista = lista.Where(x => x <= 100).ToList();
Sarrus
Jakby się czepiać to to też nie jest LINQ :P. Language Integrated Query czyli from x in lista where x <= 100 select x, ale wiemy o co chodzi ;)
somekind
To jest LINQ tylko zapisany po ludzku. :)
Aventus
@Sarrus: to jest jak najbardziej LINQ. Przyklad podany przez Ciebie to query syntax, przez somekind'a method syntax. Swoja droga zdecydowanie wole method syntax, lepiej mi sie go czyta. Zaczynanie zapytania od "from" zamiast "select" zawsze mnie jakos mylilo...
Sarrus
Ja zawsze używałem metod i wszyscy których znam też ;).

Zarejestruj się i dołącz do największej społeczności programistów w Polsce.

Otrzymaj wsparcie, dziel się wiedzą i rozwijaj swoje umiejętności z najlepszymi.