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

Zadanie algorytmiczne z wykorzystaniem rekurencji

Object Storage Arubacloud
0 głosów
175 wizyt
pytanie zadane 28 września 2023 w C i C++ przez Janchess Początkujący (480 p.)

Cześć, rozwiązuje sobie takie o to zadanie: CSES - Apple Division 

Niestety dla 17 testów otrzymuje dwa błędy, których nie jestem wstanie naprawić gdyż wydaję mi się, że sama idea progamu jak i sam algorytm działa +- poprawnie. Proszę o pomoc i wytłumaczenie dlaczego algorytm nie przechodzi poniższego testu.

test, którego nie przechodzi program:

20
934033764 747013925 113297529 621350044 4858224 896418401 823418019 490285020 811592918 318107753 122431099 971962557 68572395 269437889 506050802 903504371 908615271 406858603 39392057 816479349
#include <iostream>
#include <vector>
#include <cmath>

long long int min = 1000000000;

void appleDivision(long long int w1,long long int w2, std::vector<long long int> p, int i) {
	if ((int)p.size() == i) {
		long int s = abs(w1 - w2);
		if (s < min) min = s;
		return;
	}
	
	appleDivision(w1 + p[i], w2, p, i + 1);
	appleDivision(w1, w2+p[i], p, i + 1);
}

int main() {
	std::ios_base::sync_with_stdio(0);
	std::cin.tie(0); std::cout.tie(0);
	
	
	int n;
	std::vector<long long int> p;
	std::cin >> n;
	for (int i = 0; i < n; i++) {
		int a;
		std::cin >> a;
		p.push_back(a);
	}

	appleDivision(0, 0, p, 0);
	std::cout << min << '\n';

	return 0;
}

 

1 odpowiedź

+1 głos
odpowiedź 28 września 2023 przez adrian17 Ekspert (344,860 p.)

OK, to dość subtelna różnica, ale to chyba to:

long int s = abs(w1 - w2);

Zamień abs na std::abs.

"gołe" abs pochodzi z C, tam funkcja działała tylko na intach bo nie było przeładowywania funkcji. W związku z tym, konwersja na inta gubi Ci duże liczby. std::abs ma normalne przeładowanie dla long long.

komentarz 28 września 2023 przez Janchess Początkujący (480 p.)

Pomogło, dzięki wielkie smiley To od razu rozwiązuje mój problem z innego zadania, gdzie dla ogromnych liczb program zwracał błędne wartości. Nie wpadłbym, że abs jest temu winien...

Podobne pytania

0 głosów
1 odpowiedź 197 wizyt
0 głosów
1 odpowiedź 693 wizyt
pytanie zadane 6 kwietnia 2017 w C i C++ przez Index Nowicjusz (120 p.)

92,580 zapytań

141,433 odpowiedzi

319,665 komentarzy

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

...