Heim > Backend-Entwicklung > C++ > Hauptteil

在C程序中,以矩阵对角线模式打印数字

王林
Freigeben: 2023-09-14 18:25:06
nach vorne
480 人浏览过

任务是打印一个 n x n 的对角线模式的矩阵。

如果 n 是 3,那么打印一个对角线模式的矩阵如下:

在C程序中,以矩阵对角线模式打印数字

所以输出将会是:

在C程序中,以矩阵对角线模式打印数字

示例

Input: 3
Output:
   1 2 4
   3 5 7
   6 8 9
Input: 4
Output:
   1 2 4  7
   3 5 8 11
   6 9 12 14
   10 13 15 16
Nach dem Login kopieren

问题建议我们给出一个数字n,并生成一个n x n的矩阵,然后我们必须按照对角线的模式遍历矩阵,并将值存储在一个单独的矩阵中。

但这将增加我们代码的复杂性,所以我们将−

  • 创建一个大小为N X N的矩阵,它将在打印之前存储模式。

  • 将元素存储在模式的上三角中。观察到,当您沿对角线向下移动时,行索引增加1,列索引减少1。

  • 完成上三角后,以与上三角类似的方式存储下三角的元素,即当您沿对角线向下移动时,行索引增加1,列索引减少1。

算法

int printdiagonal(int n)
START
STEP 1: DECLARE int mat[n][n], i, j, k, d=1, m
STEP 2: LOOP FOR i = 0 AND i < n AND i++
   ASSIGN j AS i AND k AS 0
   LOOP FOR j = I AND j >= 0 AND j--
      ASSIGN mat[k][j] AS d
      INCREMENT d AND k BY 1
   END LOOP
END LOOP
STEP 3: LOOP FOR k = 1 AND k < n AND k++
   ASSIGN i AND m EQUALS TO k
   LOOP FOR j = n-1 AND j >= m AND j--
      ASSIGN mat[i][j] AS d;
      INCREMENT d AND i WITH 1
   END FOR
END FOR
STEP 4: LOOP FOR i = 0 AND i < n AND i++
   LOOP FOR j = 0 AND j < n AND j++
      PRINT mat[i][j]
   END FOR
   PRINT NEWLINE
END FOR
STOP
Nach dem Login kopieren

Example

的中文翻译为:

示例

#include 
int printdiagonal(int n){
   int mat[n][n], i, j, k, d=1, m;
   for ( i = 0; i < n; i++){
      j = i;
      k = 0;
      for ( j = i; j >= 0; j--){
         mat[k][j] = d;
         d++;
         k++;
      }
   }
   for ( k = 1; k < n; k++){
      i = m = k;
      for ( j = n-1; j >= m; j--){
         mat[i][j] = d;
         d++;
         i++;
      }
   }
   for ( i = 0; i < n; i++){
      for(j = 0; j < n; j++){
         printf("%d ", mat[i][j] );
      }
      printf("

"); } } int main(int argc, char const *argv[]){ int n = 3; printdiagonal(n); return 0; }

Nach dem Login kopieren

输出

如果我们运行上述程序,它将生成以下输出 −

1 2 4
3 5 7
6 8 9
Nach dem Login kopieren

以上是在C程序中,以矩阵对角线模式打印数字的详细内容。更多信息请关注PHP中文网其他相关文章!

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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!