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

c++ spoj tablice

Object Storage Arubacloud
0 głosów
319 wizyt
pytanie zadane 29 maja 2019 w C i C++ przez Mateusz Banaszak Nowicjusz (160 p.)

Witam wszystkich serdecznie. Próbuję rozwiązać zadanie ze spoja "tablice" nie podglądając jednocześnie gotowych rozwiązań spróbowałem napisać program, który wczytuje z ciągu znaków usuwa spacje, następnie kolejne liczby przepisuje to tablicy string, potem konwertuje string na liczby całkowite i wypisuje w odwrotnej kolejności. Mam problem z funkcją usuwającą spacje - ponieważ wczytując ciąg znaków z zadania:

7 1 2 3 4 5 6 7 - gdzie pierwszą literą jest ilość liczb n, dalej n liczb oddzielonych spacjami. Mój program odczytuje jedynkę ze spacją, co uniemożliwia poprawne przekonwertowanie pierwszego wyrazu na typ int. 

link do kodu z danymi wejściowymi: https://ideone.com/Ccp0Vi

1 odpowiedź

+1 głos
odpowiedź 29 maja 2019 przez j23 Mędrzec (194,920 p.)
A nie możesz czytać liczb ze strumienia operatorem >>? Problem spacji zniknie.
komentarz 29 maja 2019 przez Mateusz Banaszak Nowicjusz (160 p.)
Czy mógłbyś opisać to w jakimś przykładzie ? Potrafię zastosować strumień wejścia dla pojedynczych danych, ale nie wiem czy operator strumienia wejścia będę w stanie zastosować dla pętli i większej ilości danych.
komentarz 29 maja 2019 przez niezalogowany
#include <iostream>

using namespace std;

int main()
{
    string we{"7 1 2 3 4 5 6 7 "};
    string wy;
    char * znak = &we[0];
  //  mozesz tak ' ' znakspacji lub 32 to tez spacja
 //   for (int i=0;i<we.size();i++) if(we[i]!=' ') wy+=we[i];
 //lub tak
    for (int i=0;i<we.size();i++) if(isdigit(we[i])) wy+=we[i]; //we[i] przescie po kolejnyc char stringa
      cout << "Hello world!" << endl;
    cout << wy << endl;

    return 0;
}

 

1
komentarz 29 maja 2019 przez j23 Mędrzec (194,920 p.)

@Mateusz Banaszak,

unsigned t, n;
int tab[100];

std::cin >> t;

while (t--) {
	std::cin >> n;

	for (unsigned i = 0; i < n && std::cin >> tab[i]; ++i) {}

	/* tu wypisujesz w odwrotnej kolejności zawartość 'tab' */
}

 

@fisker, co to niby jest?

komentarz 29 maja 2019 przez niezalogowany
isdigit() - to bardzo potrzebna funkcja w niektórych przypadkach
komentarz 29 maja 2019 przez j23 Mędrzec (194,920 p.)
Ale co to ma do użycia operatora >>?
komentarz 29 maja 2019 przez niezalogowany
a to była taka inna opcja rozwiązania problemu, na poziomie beginer.
komentarz 29 maja 2019 przez niezalogowany

a to jeszcze inna

   int i = we.size();
    while  (i--) if(isdigit(we[i])) wy+=we[i];

,ale dobra iż się powstrzymam od komentarzy na jakiś czas podstawy w miarę utrwalone, można się zająć czymś pożytecznym.

Podobne pytania

0 głosów
0 odpowiedzi 174 wizyt
pytanie zadane 2 listopada 2021 w C i C++ przez DrTomas Nowicjusz (140 p.)
0 głosów
1 odpowiedź 627 wizyt
0 głosów
1 odpowiedź 693 wizyt
pytanie zadane 10 czerwca 2016 w C i C++ przez niezalogowany

92,576 zapytań

141,426 odpowiedzi

319,652 komentarzy

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

...