Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Ta bort element ur array

Postades av 2010-02-15 12:31:25 - Thomas Holmberg, i forum c++, Tråden har 2 Kommentarer och lästs av 4387 personer

Någon som har ett tips på hur man gör när man plockar bort ett element i en array.
Jag har en överlagrad kopieringskonstruktor som skapar en kopia av arrayen.
Och jag har en pekare som pekar på mitt första element i arrayen.

I denna sekvens skall programmet gå

! Stega igenom arr tills eftersökt värde hittas

2 Ta bort värdet

3 Tryck ihop arrayen så att inget mellanrum finns efter borttagandet.

Har använt en temp array för men undrar om det går att göra smidigare.

Thomas


Svara

Sv: Ta bort element ur array

Postades av 2010-02-15 13:45:26 - Niklas Jansson

Du har skrivit en egen array-klass?
Och jag utgår ifrån att det är ngn typ av skoluppgift?

Det finns ett antal varianter, den absolut enklaste är just den du säger, med problemet att hela arrayen måste kopieras.
Om du hade implementerat det med en länkad lista istället hade det gått fort, om det är så att "ta bort element" är en vanligt förekommande funktion. Dessutom brukar man ta sig förbi problemen om man har en RemoveAll-variant också.


Sen finns det några slags mellanlägen.
Tänk att du har element {1,2,3,4,5,6,7} och en pekare till första elementet. Du håller också reda på att du har 7 element.

Du vill sen ta bort element 4, så att du har {1,2,3,5,6,7} kvar. Vad du då kan göra är att säga till att element 4 är borttaget, så att du får {1,2,3,4*,5,6,7}. Du måste då överlagra index-operatorn så att du stegar igenom och struntar i de elementen, mycket tidskrävande.

En annan variant är att du har flera pekare, med tillhörande "antal element"-räknare, du får då {1,2,3},{5,6,7} med antal element 3,3

Sen kan man tänka sig komplicerade lösningar med hashtabeller eller med cachade lägen (så att man "rensar upp" först när det behövs, etc.)


Svara

Sv:Ta bort element ur array

Postades av 2010-02-16 16:48:08 - Thomas Holmberg

Jag hade dessa överlagrade funktioner så det gick bra
Person &operator[](int i);
Person operator[](int i) const;

det var ju bara att loopa fram till aktuellt index "ta bort" objektett och sedan

arr[ind = arr[ind + 1]] ;
Man kunde ju tilldela i en array från sig själv.
Ja det är skola
och vi har ej kommit till länkade listor ännu.

Thomas


Svara

Nyligen

  • 14:24 CBD regelbundet?
  • 14:23 CBD regelbundet?
  • 14:22 Har du märkt några verkliga fördel
  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 614
27 953
271 709
486
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies