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

Program crashuje przy sortowaniu

VPS Starter Arubacloud
0 głosów
138 wizyt
pytanie zadane 14 grudnia 2017 w C i C++ przez koliber Początkujący (400 p.)

Poniższy kod zdaje się poprawnie sortować (sortowanie shella), bo sprawdzalem coutami, ale z niewiadomych dla mnie przyczyn crashuje się.

 

Oto część kodu, jak trzeba wstawić cały program dajcie znać:

#include <iostream>
#include <cstdlib>   // for srand and rand
#include <ctime>     // for time
#include <math.h>

using namespace std;

int potega(int podst,int pot){
    int wynik = podst;
    for(int i = 1; i < pot; i++){
        wynik = wynik *podst;
    }
    return wynik;
}

void shellON32(int tab[], int n){
    int k = 1;
    int przerwa = 2*(n / potega(2, k+1)) +1;
    cout << "przerwa" << przerwa << endl;
    while(przerwa > 0){

        int j = 0;
        for(int i = przerwa; i < n; i++){
            int temp = tab[i];

            for(j = i; j >= przerwa && tab[j - przerwa] > temp; j = j - przerwa){
                tab[j] = tab[j - przerwa];
            }

            tab[j] = temp;
        }
        k++;
        przerwa = 2*(n / potega(2, k+1)) +1;

    }

}

int main()
{
    //srand(time(0));

    int n = 30;
    int tab[n];
    for(int i = 0; i < n; i++){
        tab[i] = rand() % 100+1;
    }

    for(int i = 0; i < n; i++){
        cout << tab[i] << endl;
    }


    shellON32(tab, n);

    cout << "sortu sortu" << endl;

    for(int i = 0; i < n; i++){
        cout << tab[i] << endl;
    }




    return 0;
}

 

Będę wdzięczny za wskazanie błędu

1 odpowiedź

0 głosów
odpowiedź 14 grudnia 2017 przez k222 Nałogowiec (30,150 p.)

Masz 2 razy tę samą linię kodu:

przerwa = 2*(n / potega(2, k+1)) +1;

w 18 i 33 linijce - usuń 1 z nich (pewnie tą drugą) i powinno być ok

Podobne pytania

0 głosów
0 odpowiedzi 76 wizyt
pytanie zadane 18 kwietnia 2020 w Java przez princeV Nowicjusz (140 p.)
0 głosów
0 odpowiedzi 179 wizyt
pytanie zadane 25 maja 2020 w Java przez miko98 Nowicjusz (150 p.)
0 głosów
1 odpowiedź 157 wizyt
pytanie zadane 29 października 2017 w Java przez barteku12 Obywatel (1,340 p.)

92,454 zapytań

141,263 odpowiedzi

319,099 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!

...