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

problem z przypisaniem do tablicy wartości

Object Storage Arubacloud
0 głosów
160 wizyt
pytanie zadane 19 lipca 2019 w C i C++ przez Semcio Początkujący (340 p.)

Pracuję nad tym zadaniem: https://main2.edu.pl/c/konkurs-wstepu-do-programowania/p/pie/ (uproszczona wersja, zakladam ze wartość się pojawi co najmniej raz)

chcę go zrobić tak: tablica ma rozmiar n, interesujaca nas wartość to k. najpierw deklaruje zmienne i tą tablice wartości do wczytania. pozniej wprowadzam zmienna "l" ktora mi mowi razy pojawilo się k w mojej tablicy (licze te pojawienia za pomoca petli for). No i teraz chce zrobic tablice d[l]. ktorej elementami beda indeksy "a" takie ze t[a]=k. Chciałem zastosować instrukcje przypisania, cos w stylu if (t[a]=k) d[j]=a; j++, else j=j.

Pozniej chciałem wybrać minimum i maksimum z elementow tablicy d i to rozwiazalo by zadanie(ale do tego jeszcze nawet nie doszedlem bo wystapil pewien problem).

Problem jest taki ze program dziala tylko jakos dziwnie. Jak poprosilem go, zeby wyswietlil mi elementy tablicy d(czyli petla for) to okazalo sie ze w tablicy d sa jakies duze liczby. nie wiem co jest zle, przeciez dalem instrukcje przypisania. prosze o pomoc, dziekuje z gory :)

 

tutaj moj kod:

#include <iostream>
using namespace std;
// chce aby n bylo objetoscia poczatkowej tablicy wartości akcji
int main() {
    int n;
    cin >> n;
    int k; //  to wartosc akcji na ktorej nam zalezy 
    cin >> k;
    int l=0;
    int t[n];
    for (int i = 0; i < n; i++)
        cin >> t[i];
    for (int i = 0; i <=n-1; i++)
       if (t[i]==k)
        {l++;}
      // cout<<l<<endl;} //tu tez widac ze i dziala
       else
       {l=l;}
       //cout<<l<<endl; // tu można sobie zobaczyć że "l" to faktycznie liczba powtorzen wartosci k

// teraz nowa tablica d

        int d[l];
        for (int a = 0; a < n; a++)
        {int j=0;
        if (t[a]=k)
        {a=d[j]; // chciałbym zeby elementami "d" byly indeksy "a" takie ze t[a]=k
        j++;
               // cout<<d[j]<<endl;
            }

        else
            {j=j;}
                   // cout<<d[j]<<endl;}
        }
for (int x = 0; x <=l-1; x++)
        cout << d[x] << " ";


}

 

1 odpowiedź

+1 głos
odpowiedź 19 lipca 2019 przez adrian17 Ekspert (344,860 p.)

pozniej wprowadzam zmienna "l" ktora mi mowi razy pojawilo się k w mojej tablicy (licze te pojawienia za pomoca petli for). No i teraz chce zrobic tablice d[l]. ktorej elementami beda indeksy "a" takie ze t[a]=k

To trochę przekombinowane ;) Podpowiem, że jest znacznie, znacznie prostszy sposób znalezienia pierwszego i ostatniego wystąpienia wartości, bez żadnych dodatkowych tablic.

A tak ogólnie, to kompilator mi tu ostrzega że jest dużo prawdopodobnie bezsensownego kodu, na przykład:

main.cpp:18:10: warning: explicitly assigning value of variable of type 'int' to itself [-Wself-assign]
       {l=l;}
        ~^~
main.cpp:26:17: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
        if (t[a]=k)

main.cpp:10:10: warning: variable length arrays are a C99 feature [-Wvla-extension]
    int t[n];

Proponuję przemyśleć rozwiązanie, przeformatować kod, jak wciąż będzie się sypać to zapytać o dalszą pomoc lub nauczyć się używania debuggera ;)

Podobne pytania

0 głosów
2 odpowiedzi 318 wizyt
0 głosów
1 odpowiedź 129 wizyt

92,568 zapytań

141,420 odpowiedzi

319,622 komentarzy

61,954 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!

...