矩阵中填数. 当给出 N*N 的矩阵要求按蛇形填,回转填数

//蛇形填法

 #include "stdio.h"
void main()
{
    int n, i, j;
    scanf("%d", &n);
    int t = n*n;
    for(i = n; i > 0; i--)
    {
        for(j = n; j > 0; j--)
            printf("%5d", t--);
        printf("/n");
    }
}[/code]
[code]// 6.2
#include "stdio.h"
#define N 15
void main()
{
    int sum, j, t = 1, start, end;
    static int a[N][N];
    for(sum = 0; sum < 2*N -1; sum++)
    {
        start = (sum < N)?0:sum-(N-1);
        end   = (sum < N)?sum:(N-1);
        for(j = start; j <= end; j++)
            (sum%2)?(a[j][sum-j] = t++):(a[sum-j][j] = t++);  //(sum%2)
控制环绕方向
    }
    for(sum = 0; sum < N; sum++)
    {
        for(j = 0; j < N; j++)
            printf("%5d", a[sum][j]);
        printf("/n");
    }

}

用于控制方向, 若改为a[j][i], 则方向相反
#define N 10
void main()
{
    static int a[N][N], i, j, num;
    int start = 0, end = N -1;
    for(int t =0; t <= N/2; t++, start++, end--, i++, j++)
    {   
        for(i = start; i < end; i++)
            a[i][j] = ++num;
        for(j = start; j < end; j++)
            a[i][j] = ++num;
        for(i = end; i > start; i--)
            a[i][j] = ++num;
        for(j = end; j > start; j--)
            a[i][j] = ++num;
        if(start == end)
            a[start][end] = ++num;
    }
    for(i = 0; i < N; i++)
    {
        for(j = 0; j < N; j++)
            printf("%4d", elem);
        printf("/n");
    }

}


//回转填法
#include <stdio.h>
#define elem a[i][j] //

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值