Heim > Backend-Entwicklung > C++ > C++-Programm zum Ermitteln des Maximalwerts von i

C++-Programm zum Ermitteln des Maximalwerts von i

PHPz
Freigeben: 2023-09-15 20:09:08
nach vorne
1091 Leute haben es durchsucht

C++-Programm zum Ermitteln des Maximalwerts von i

Angenommen, wir haben eine ganzzahlige Sequenz „seq“ und ein Array von ganzzahligen Paaren „pairs“ der Größe m, das die ganzen Zahlen 0 bis n - 1 enthält. Nun führen wir die folgenden Operationen so oft wie möglich an seq durch, damit seq[i] = i (0 ≤ i

  • Wir müssen eine ganze Zahl j wählen, wobei 0

Wir muss den Maximalwert von i finden, sodass seq[i] = i ist, nachdem die Operation mehrmals ausgeführt wurde.

Wenn also die Eingabe n = 4, m = 2, seq = {0, 3, 2, 1}, Paare = {{0, 1}, {2, 3}} ist, dann ist die Ausgabe 2.

Der maximal mögliche Wert beträgt 2.

Um dieses Problem zu lösen, führen wir die folgenden Schritte aus:

N := 100
Define an array tp of size: N.
Define arrays vtmp, vis of size N.
Define a function dfs(), this will take j, k,
tp[j] := k
insert j at the end of vtmp[k]
for each value b in vis[j], do:
   if tp[b] is not equal to 0, then:
      Ignore following part, skip to the next iteration
   dfs(b, k)
res := 0
for initialize i := 0, when i < n, update (increase i by 1), do:
   if seq[i] is same as i, then:
      (increase res by 1)
for initialize i := 0, when i < m, update (increase i by 1), do:
   a := first value of pairs[i]
   b := second value of pairs[i]
   insert b at the end of vis[a]
  insert a at the end of vis[b]
idx := 1
for initialize i := 0, when i < n, update (increase i by 1), do:
if tp[i] is same as 0, then:
dfs(i, idx)
for each element j in vtmp[idx], do:
if tp[seq[j]] is same as idx and seq[j] is not equal to j, then:
(increase res by 1)
(increase idx by 1)
print(res)
Nach dem Login kopieren

Beispiel

Sehen wir uns zum besseren Verständnis die folgende Implementierung an: −

#include <bits/stdc++.h>
using namespace std;
const int INF = 1e9;
#define N 100
int tp[N];
vector<int> vtmp[N], vis[N];
void dfs(int j, int k){
   tp[j] = k;
   vtmp[k].push_back(j);
   for(auto b : vis[j]) {
      if(tp[b] != 0)
         continue;
      dfs(b, k);
   }
}
void solve(int n, int m, int seq[], vector<pair<int, int>> pairs) {
   int res = 0;
   for(int i = 0; i < n; i++){
      if(seq[i] == i)
         res++;
   }
   for(int i = 0; i < m; i++){
      int a = pairs[i].first;
      int b = pairs[i].second;
      vis[a].push_back(b);
      vis[b].push_back(a);
   }
   int idx = 1;
   for(int i = 0; i < n; i++) {
      if(tp[i] == 0) {
         dfs(i, idx);
         for(auto j: vtmp[idx]){
            if(tp[seq[j]] == idx && seq[j] != j)
               res++;
         }
         idx++;
      }
   }
   cout<< res;
}
int main() {
   int n = 4, m = 2, seq[] = {0, 3, 2, 1};
   vector<pair<int,int>> pairs = {{0, 1}, {2, 3}};
   solve(n, m, seq, pairs);
   return 0;
}
Nach dem Login kopieren

Eingabe

4, 2, {0, 3, 2, 1}, {{0, 1}, {2, 3}}
Nach dem Login kopieren

Ausgabe

2
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonC++-Programm zum Ermitteln des Maximalwerts von i. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:tutorialspoint.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage