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

Zadanie ukryte liczby szkopuł

Object Storage Arubacloud
0 głosów
141 wizyt
pytanie zadane 9 września 2023 w C i C++ przez Sophix Nowicjusz (170 p.)

Hej, zrobiłam zadanie ukryte liczby jednak w trzech końcowych testach nie dostałam pełnej punktacji, przez co końcowy wynik to 92. Wydaje mi się że jest to spowodowane czasem wykonania, aczkolwiek mogę się mylić.

#include <bits/stdc++.h>
using namespace std;
int main (){
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    long long suma;
    long long n, i;
    cin >> n;
    string napis;
    string nowe;
    cin >> napis;
    nowe="";
    suma=0;
    for (i=0; i<n; ++i){
        if ((napis[i]>='0')&&(napis[i]<='9')){
            nowe=nowe+napis[i];
        }
        else
            if(nowe.size()>0){
                suma= suma+stol(nowe);
                nowe="";
            }}
    if(nowe.size()>0)
        suma= suma+stol(nowe);
    cout << suma;
    return 0;
}

komentarz 9 września 2023 przez adrian17 Ekspert (344,860 p.)

A tak zupełnie na boku:

cout.tie(0);

AFAIK tie(0) na cout nic nie robi.

    long long suma;
    long long i;
    string nowe;
    nowe="";
    suma=0;
    for (i=0; i<n; ++i){

Deklaruj zmienne przed użyciem i od razu inicjalizuj, takie rozwlekanie jak masz teraz tylko zmniejsza czytelność.

    long long suma = 0;
    string nowe = ""; // to ="" w zasadzie tez jest niepotrzebne, bo string z definicji zaczyna jako ""
    for (int i=0; i<n; ++i){

 

1 odpowiedź

0 głosów
odpowiedź 9 września 2023 przez adrian17 Ekspert (344,860 p.)

Wydaje mi się że jest to spowodowane czasem wykonania, aczkolwiek mogę się mylić.

Ale strona pokazuje czy czas wykonania dla testów przekroczył limit czasu, więc nie wiem czemu zgadujesz :P

Wkleiłem Twój kod dosłownie na stronę i dostałem 100/100. Natomiast faktycznie kilka testów było bliskich limitu czasu.

Idealnie mógłbyś zoptymalizować kod nie tworząc stringa `nowe` tylko od razu na żywo liczyć nową liczbę do dodania.

Natomiast jest jeszcze jeden szybki myk który też znacząco pomoże bez przepisywania pół kodu:

nowe = nowe + napis[i];
// zamien na
nowe += napis[i];

W ten sposób kod będzie doklejał znaki na koniec istniejącego stringa zamiast w kółko tworzyć i niszczyć nowe stringi.

Podobne pytania

0 głosów
1 odpowiedź 98 wizyt
pytanie zadane 12 września 2023 w C i C++ przez Sophix Nowicjusz (170 p.)
+1 głos
0 odpowiedzi 109 wizyt
pytanie zadane 25 lipca 2023 w C i C++ przez Sophix Nowicjusz (170 p.)
0 głosów
1 odpowiedź 195 wizyt
pytanie zadane 30 maja 2023 w C i C++ przez Szyszka Gaduła (3,490 p.)

92,579 zapytań

141,432 odpowiedzi

319,657 komentarzy

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

...