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

Problem z kodem

Object Storage Arubacloud
0 głosów
134 wizyt
pytanie zadane 6 października 2016 w C i C++ przez niezalogowany

Witam , rozwiązuję zadanie z OIG, ale nie z tym problem. Zrobiłem na structurach i przy wpisywaniu w 4 linijce na przykład 2 2 to wyskakuje naruszenie ochrony pamięci. Działam na Linuksie. Mam coś źle w kodzie?

#include <iostream>

using namespace std;

struct zamiany
{
    int l1, l2;
};

int main()
{
    int d, n;
    cin>>d;
    string w1, w2;
    cin>>w1;
    cin>>w2;
    cin>>n;
    int t[n];
    zamiany z[n];
    for (int i = 0; i<n-1; i++)
    {
        cin>>z[i].l1>>z[i].l2;
    }
    for (int i = 0; i<n-1; i++)
    {
        char a = ' ';
        a = w1[z[n].l1];
        w1[z[n].l1] = w2[z[n].l2];
        w2[z[n].l2] = a;
        for (int j=0; j<d-1; j++)
        {
            if (w1[j]>w2[j])
                t[j] = 1;
            else if (w1[j]<w2[j])
                t[j] = 2;
            else
                t[j] = 0;
            cout<<t[j]<<endl;
        }
    }
}

 

1 odpowiedź

+1 głos
odpowiedź 6 października 2016 przez criss Mędrzec (172,590 p.)
edycja 6 października 2016 przez criss
z[n].l1

itd..

Tablica o wielkości n ma n -1 komórek (edit: lol, tfu, sorry, oczywiście miałem na myśli, że ostatnia komórka ma "nr" n - 1). Poza tym coś mi się wydaje, że tam powinno być i.

Pętle for:

for (int i = 0; i<n-1; i++)

Nie dochodzisz do ostatniej komórki w przypadku wszystkich pętli w twoim kodzie. Tak będzie dobrze:

for (int i = 0; i < n; i++)

PS:

        a = w1[z[n].l1];
        w1[z[n].l1] = w2[z[n].l2];
        w2[z[n].l2] = a;

Od tego jest std::swap.

komentarz 6 października 2016 przez niezalogowany
Ok, dzięki! Sam program jeszcze dobrze nie liczy ale do tego dojdę.

Podobne pytania

0 głosów
2 odpowiedzi 236 wizyt
pytanie zadane 26 maja 2022 w Sprzęt komputerowy przez FROSTtoTOST Nowicjusz (160 p.)
0 głosów
1 odpowiedź 322 wizyt
pytanie zadane 7 marca 2022 w Sprzęt komputerowy przez Tadzio001 Obywatel (1,610 p.)
0 głosów
1 odpowiedź 292 wizyt

92,619 zapytań

141,468 odpowiedzi

319,786 komentarzy

62,001 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!

...