Heim > Backend-Entwicklung > C++ > C++-Programm zum Drucken spiralförmiger Zahlenmuster

C++-Programm zum Drucken spiralförmiger Zahlenmuster

WBOY
Freigeben: 2023-09-05 18:25:06
nach vorne
1583 Leute haben es durchsucht

C++-Programm zum Drucken spiralförmiger Zahlenmuster

Die Anzeige von Zahlen in verschiedenen Formaten ist eines der grundlegenden Codierungsprobleme beim Lernen.

Verschiedene Codierungskonzepte wie bedingte Anweisungen und Schleifenanweisungen. haben In verschiedenen Programmen verwenden wir Sonderzeichen wie Sternchen zum Ausdrucken von Dreiecken oder Quadrat. In diesem Artikel drucken wir Zahlen in Spiralform, genau wie Quadrate in C++.

Wir nehmen die Anzahl der Zeilen n als Eingabe und beginnen in der oberen linken Ecke Bewegen Sie sich nach rechts, dann nach unten, dann nach links, dann nach oben, dann wieder nach rechts und so weiter usw.

Spiralmuster und Zahlen

1   2   3   4   5   6   7
24  25  26  27  28  29  8
23  40  41  42  43  30  9
22  39  48  49  44  31  10
21  38  47  46  45  32  11
20  37  36  35  34  33  12
19  18  17  16  15  14  13
Nach dem Login kopieren

Um dieses Problem zu lösen, verwenden wir eine 2D-Matrix der Größe n x n, in diesem Fall nehmen wir n = 7. Füllen Sie dann die Matrix spiralförmig aus, beginnend in der oberen linken Ecke. endgültiger Ausdruck die gesamte Matrix. Hier drucken wir in der ersten Zeile von 1 bis 7 und dann ändert der Prozess seine Werte Richtung, bewegen Sie sich nach unten zu 13, dann nach links zu 19 und schließlich Gehen Sie nach oben bis 24, dann nach rechts und so weiter. Schauen wir uns einen besseren Algorithmus an verstehen.

Algorithmus

  • Geben Sie s als Anzahl der Zeilen ein
  • Erstellen Sie eine SxS-Matrix und initialisieren Sie sie mit 0
  • Anzahl: = 1
  • Initialisieren Sie i, j, m auf 0
  • Initialisieren Sie n := s - 1, p := 0 und q := s - 1
  • Wenn die Anzahl s * s nicht überschreitet, führen Sie die Ausführung aus
    • Für j im Bereich von p bis q machen Sie
      • mat[ m, j ] := num
      • Zahl := Zahl + 1
    • Ende
    • Meter:=Meter+1
    • Für i von m bis n führe ich aus
      • mat[ i, q ] := num
      • Zahl := Zahl + 1
    • Ende
    • q := q - 1
    • Für den Bereich von j von q bis p subtrahiere jedes Mal 1 und führe es aus
      • mat[n, j] := num
      • Zahl := Zahl + 1
    • Ende
    • n := n - 1
    • Für i von n bis m dekrementiere i um 1 und führe es aus
      • mat[ i, p ] := num
      • Zahl := Zahl + 1
    • Ende
    • p := p + 1
  • Ende
  • Für i von 0 bis s-1 gehen Sie wie folgt vor
    • Für j im Bereich von 0 bis s - 1 gilt Folgendes:
      • Show mat[ i, j ]
    • Ende
    • Cursor zur nächsten Zeile bewegen
  • Ende
Die chinesische Übersetzung von

Beispiel

lautet:

Beispiel

#include <iostream>
using namespace std;
void solve( int s ){
   int mat[ s ][ s ] = {0};
   int i, j, m, n, p, q, num;
   num = 1; // start count from 1
   i = 0;
   j = 0;
   m = 0; // row index lower limit
   n = s - 1; // row index upper limit
   p = 0; // column index lower limit
   q = s - 1; // column index upper limit
   while ( num <= s * s ) {
   
      // place numbers horizontally left to right
      for ( j = p; j <= q; j++ ) {
         mat[ m ][ j ] = num;
         num = num + 1;
      }
      m = m + 1;
   
      // fill vertically from top to bottom
      for ( i = m; i <= n; i++ ) {
         mat[ i ][ q ] = num;
         num = num + 1;
      }
      q = q - 1;

      // fill horizontally from right to left
      for ( j = q; j >= p; j-- ) {
         mat[ n ][ j ] = num;
         num = num + 1;
      }
      n = n - 1;

      // fill vertically from bottom to top
      for ( i = n; i >= m; i-- ) {
         mat[ i ][ p ] = num;
         num++;
      }
      p = p + 1;
   }

   // display the mat
   for ( i = 0; i < s; i++ ) {
      for ( j = 0; j < s; j++ ) {
         printf("%d\t", mat[i][j]);
      }
      printf("\n");
   }
}
int main(){
   int n = 5;
   cout << "Spiral numbers for " << n << " lines." << endl;
   solve( n );
}
Nach dem Login kopieren

Ausgabe

Spiral numbers for 5 lines.
1	2	3	4	5	
16	17	18	19	6	
15	24	25	20	7	
14	23	22	21	8	
13	12	11	10	9
Nach dem Login kopieren

Ergebnisse ausgeben (wenn n = 12)

Spiral numbers for 12 lines.
1	2	3	4	5	6	7	8	9	10	11	12	
44	45	46	47	48	49	50	51	52	53	54	13	
43	80	81	82	83	84	85	86	87	88	55	14	
42	79	108	109	110	111	112	113	114	89	56	15	
41	78	107	128	129	130	131	132	115	90	57	16	
40	77	106	127	140	141	142	133	116	91	58	17	
39	76	105	126	139	144	143	134	117	92	59	18	
38	75	104	125	138	137	136	135	118	93	60	19	
37	74	103	124	123	122	121	120	119	94	61	20	
36	73	102	101	100	99	98	97	96	95	62	21	
35	72	71	70	69	68	67	66	65	64	63	22	
34	33	32	31	30	29	28	27	26	25	24	23
Nach dem Login kopieren

Fazit

Die Anzeige von Zahlenmustern ist ein ziemlich häufiges Problem beim Erlernen des Programmierens Sprache. In diesem Artikel haben wir gelernt, wie man Zahlen in dem Quadrat anzeigt, in dem sich das Element befindet Drucken Sie in C++ spiralförmig, beginnend in der oberen linken Ecke und nach unten Am Ende der Spalte n bewegen wir uns nach unten, am Ende der Zeile n bewegen wir uns dann nach links Nachdem Sie die erste Reihe erreicht haben, gehen Sie bis zur zweiten Reihe vor und wiederholen Sie diesen Vorgang immer wieder, bis ... Vervollständigen Sie das gesamte Quadrat. Im Gegensatz zu anderen numerischen Musterproblemen ist ein 2D-Array erforderlich Lösen Sie dieses Problem effektiv.

Das obige ist der detaillierte Inhalt vonC++-Programm zum Drucken spiralförmiger Zahlenmuster. 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
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage