Heim > Backend-Entwicklung > C++ > Eine interessante Möglichkeit, Binärzahlen von 1 bis n zu generieren?

Eine interessante Möglichkeit, Binärzahlen von 1 bis n zu generieren?

PHPz
Freigeben: 2023-09-11 21:09:02
nach vorne
1024 Leute haben es durchsucht

Eine interessante Möglichkeit, Binärzahlen von 1 bis n zu generieren?

Hier sehen wir eine interessante Methode zur Generierung von Binärzahlen von 1 bis n. Wir tun dies mithilfe von Warteschlangen. Zunächst wird die erste Binärzahl „1“ in der Warteschlange gehalten. Entfernen Sie nun wiederholt Elemente aus der Warteschlange, drucken Sie sie aus, fügen Sie 0 am Ende des vorherigen Elements und 1 am Ende des vorherigen Elements hinzu und fügen Sie sie in die Warteschlange ein. Schauen wir uns den Algorithmus an, um auf diese Idee zu kommen. Die chinesische Übersetzung von

Algorithm

genBinaryNumbers(n)

Begin
   define empty queue.
   insert 1 into the queue
   while n is not 0, do
      delete element from queue and store it into s1
      print s1
      s2 := s1
      insert s1 by adding 0 after it into queue
      insert s1 by adding 1 after it into queue
      decrease n by 1
   done
End
Nach dem Login kopieren

Example

lautet:

Example

#include <iostream>
#include <queue>
using namespace std;
void genBinaryNumbers(int n){
   queue<string> qu;
   qu.push("1");
   while(n != 0){
      string s1 = qu.front();
      qu.pop();
      cout << s1 << " ";
      string s2 = s1;
      qu.push(s1 + "0");
      qu.push(s1 + "1");
      n--;
   }
}
int main() {
   int n = 15;
   genBinaryNumbers(n);
}
Nach dem Login kopieren

Output

1 10 11 100 101 110 111 1000 1001 1010 1011 1100 1101 1110 1111
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonEine interessante Möglichkeit, Binärzahlen von 1 bis n zu generieren?. 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