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

Zadanie Przemytnicy c++

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

Cześć mam problem z zadaniem przemytnicy. Napisałem już kod, który według mnie powinien działać, a na końcu i tak zawsze wypisuje 0. Siedzę nad tym zadaniem już 3 godziny, czy mógłby ktoś mi wytłumaczyć, gdzie popełniłem błąd?
 

#include <bits/stdc++.h>
using namespace std;

const int MAXN=1e4+7;
int dist[2*MAXN];
vector<pair<int,int>> G[2*MAXN];

void Dijkstra(int start)
{
	priority_queue<pair<int,int>> Q;
	Q.push({0, start});
	while (Q.size())
	{
		auto [d, v]=Q.top();
		Q.pop();
		if (dist[v]<=-d)
			continue;
		dist[v]=-d;
		for (auto [u,w] : G[v])
		{
			if (dist[u]>dist[v]+w)
				Q.push({-(dist[v]+w),u});
		}
	}
}

int main()
{
	ios_base::sync_with_stdio(0);
	cin.tie(0);
	int n;
	cin>>n;
	for (int i=1; i<=n; i++)
	{
		int number;
		cin>>number;
		G[i].push_back({i+n, number/2});
	}
	
	int m;
	cin>>m;
	
	for (int i=1; i<=m; i++)
	{
		int a, b, c;
		cin>>a>>b>>c;
		G[a].push_back({b, c});
	}
	
	Dijkstra(1);
	cout<<dist[n+1];
	return 0;
}

 

1 odpowiedź

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

Odpalałeś to w debuggerze, albo np wypisując wszystkie zmienne co drugą linię?

Bo na razie ten kod praktycznie nic nie robi bo:

if (dist[v]<=-d) {
    continue;
}

Na początku dist[START] jest 0 i `d` jest 0, więc kończysz pętlę i od razu wychodzisz z funkcji.

(tbh niezbyt rozumiem o co chodzi z tym minusem)

BTW druga obserwacja na szybko: z tego co rozumiem, opłatę celną zrealizowałeś przez przejście z I do I+N. Ale nigdzie nie widzę żebyś miał krawędzie na tych +N wierzchołkach po których dijkstra mógłby wrócić z powrotem do złota N+1.

komentarz 9 września 2023 przez Bartek7630 Nowicjusz (190 p.)

Z minusem chodzi o to, że w kolejce chcę, by wierzchołek mniejszy był pobierany jako pierwszy, więc używam -d , aby go zamienić. Poprawiłem trochę ten kod i stworzyłem nowe połączenia oraz dodałem w kodzie linię fill(dist,dist+2*n+1,1e9);, o której wcześniej zapomniałem, żeby program działał. Teraz już wszystko działa i zadanie wchodzi na 100%, dzięki za pomoc i podpowiedź z tymi nowymi połączeniami :). Poprawiony i działający kod:
 

#include <bits/stdc++.h>
using namespace std;

const int MAXN=1e5+7;
int dist[2*MAXN];
vector<pair<int,int>> G[2*MAXN];

void Dijkstra(int start)
{
	fill(dist,dist+2*n+1,1e9);
	priority_queue<pair<int,int>> Q;
	Q.push({0, start});
	while (Q.size())
	{
		auto [d, v]=Q.top();
		Q.pop();
		if (dist[v]<=-d)
			continue;
		dist[v]=-d;
		for (auto [u,w] : G[v])
		{
			if (dist[u]>dist[v]+w)
				Q.push({-(dist[v]+w),u});
		}
	}
}

int main()
{
	ios_base::sync_with_stdio(0);
	cin.tie(0);
	int n;
	cin>>n;
	for (int i=1; i<=n; i++)
	{
		int number;
		cin>>number;
		G[i].push_back({i+n, number/2});
	}
	
	int m;
	cin>>m;
	
	for (int i=1; i<=m; i++)
	{
		int a, b, c;
		cin>>a>>b>>c;
		G[a].push_back({b, c});
		G[a+n].push_back({b+n, c});
	}
	
	Dijkstra(1);
	cout<<dist[n+1];
	return 0;
}

 

Podobne pytania

0 głosów
0 odpowiedzi 361 wizyt
pytanie zadane 3 stycznia 2022 w C i C++ przez olcia Nowicjusz (200 p.)
0 głosów
1 odpowiedź 546 wizyt
pytanie zadane 3 stycznia 2022 w C i C++ przez olcia Nowicjusz (200 p.)
0 głosów
1 odpowiedź 271 wizyt
pytanie zadane 7 lutego 2023 w C i C++ przez polandonion Mądrala (7,040 p.)

92,579 zapytań

141,429 odpowiedzi

319,657 komentarzy

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

...