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

Optymalizacja algorytmu, który zeruje

VPS Starter Arubacloud
0 głosów
295 wizyt
pytanie zadane 12 stycznia 2018 w C i C++ przez marcin_kub Obywatel (1,420 p.)
edycja 12 stycznia 2018 przez marcin_kub

Cześć Wam

Potrzebuję pomocy przy optymalizacji pewnego algorytmu. Polega on na tym, że mam tablicę z dużą ilością elementów i odczytuję z niej 3 liczby, co każdorazowy obieg pętli. I muszę przepisać te liczby do nowej tablicy, tylko zamiast wybranych przez użytkownika numerów (odpowiedniki liczb) [1 2 3] ma być wpisane 0.

Np.:

odczytuję po 3 liczby z tablicy [20 30 40 10 20 30] i użytkownik chce żeby nowa tablica wyglądała tak: [0 30 40 0 20 30], albo [40 0 30 10 0 30] czy [0 30 0 0 20 0].

Jest 8 opcji:

  • zeruje pierwszą liczbę
  • zeruje drugą liczbę
  • zeruje trzecią liczbę
  • zeruje pierwszą i drugą
  • zeruje pierwszą i trzecią
  • zeruje drugą i trzecią
  • zeruje wszystkie
  • nie zeruje nic (zostawia jak jest)

Możliwości algorytmu to:

- można wpisać dowolną liczbę zer

- można przesuwać się po tablicy o wartości 1,2,3, nie można się przesunąć o zero miejsc

- można przepisać dowolną liczbę liczb z tablicy pierwszej

Chciałem to wszystko umieścić w jednej pętli, najlepiej for lub dwóch.

Do czego mi jest to potrzebne?

Potrzebne mi jest to do możliwości wczytywania większego rozmiaru plików *.bmp, bo na razie wygląda to tak, że wczytuję do inta rozmiar całego pliku w bajtach i próbuję go przepisać do nowego pliku *.bmp... następuje przeładowanie bufora dla plików powyżej kilkudziesięciu MB.

Kod

komentarz 12 stycznia 2018 przez hhh Gaduła (4,110 p.)
Może zamiast inta zastosuj pojemniejszy typ zmiennej, np.: unsigned long long albo long double?
komentarz 12 stycznia 2018 przez j23 Mędrzec (194,920 p.)

następuje przeładowanie bufora dla plików powyżej kilkudziesięciu MB.

Nic dziwnego. Ładujesz całą bitmapę do pamięci stosu, który ma ograniczoną wielkość do paru MB:

int bajty_obrazka = (rozmiar - poczatek);

char obrazek[bajty_obrazka]; // <--- tak nie można w C++

Zresztą wydaje mi się, że już ktoś Ci pisał w innym wątku, na czym polega błąd. Tak czy siak, prawidłowo powinno to wyglądać tak:

std::vector<uint8_t> obrazek(rozmiar - poczatek);

plik_bmp.read(reinterpret_cast<char*>(&obrazek.front()), obrazek.size());

 

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

0 głosów
1 odpowiedź 313 wizyt
pytanie zadane 14 lutego 2018 w C i C++ przez Kurczak Użytkownik (940 p.)
0 głosów
1 odpowiedź 771 wizyt
pytanie zadane 2 grudnia 2017 w Python przez nastrand Nowicjusz (150 p.)
+1 głos
1 odpowiedź 284 wizyt

92,453 zapytań

141,262 odpowiedzi

319,088 komentarzy

61,854 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...