| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 323 人关注过本帖, 1 人收藏
标题:求更好的方法
只看楼主 加入收藏
飞扬hu
Rank: 2
等 级:论坛游民
帖 子:36
专家分:22
注 册:2011-6-17
结帖率:66.67%
收藏(1)
已结贴  问题点数:20 回复次数:2 
求更好的方法
打印一个 N*N 的方阵,N为每边           N=15  打印出下面图形
 字符的个数(3<N<20), 要求最               TTTTTTTTTTTTTTT
 外一层为"T", 第二层为"J", 从第三层               TJJJJJJJJJJJJJT
 起每层依次打印数字 1,2,3,...                     TJ11111111111JT
 (右图以N为15为例)                           TJ12222222221JT
                                                  TJ12333333321JT
                                                  TJ12344444321JT
                                                  TJ12345554321JT
                                                  TJ12345654321JT
                                                  TJ12345554321JT
                                                  TJ12344444321JT
                                                  TJ12333333321JT
                                                  TJ12222222221JT
                                                  TJ11111111111JT
                                                  TJJJJJJJJJJJJJT
                                                  TTTTTTTTTTTTTTT
#include<stdio.h>
#include<stdlib.h>
//这里主要是运用了规则矩阵的操作
void main()
{
    int i ,j,flag_i,flag_j, N;
    char a[200];
    printf("输入一个数N(3<N<20)");
    scanf("%d",&N);
    if(( N>=20 )||(N<=3))    //主要对输入的数做一定的要求
    {
        printf("输入的数据有问题");
        exit(0);
    }
    for (i = 0;i < (N+1)/2;i++)//利用一个一维数组进行存储这些矩阵
    {
        for(j = 0;j <=i;j++)
        {
            if(j==0)
                a[i*(i-1)+j]='T';
            else
            {
                if(j==1)
                    a[i*(i-1)+j]='J';
                else
                    a[i*(i-1)+j]='0'+j-1;
            }            
        }
    }
   
    for(i=0;i<N;i++)  //按要求对所存储的矩阵进行展开
    {
        flag_i = i;
        for(j=0;j<N;j++)
        {
            flag_j = j;
            if(i>=(N+1)/2)
                i=N-i-1;
            if(j>=(N+1)/2)
                j=N-j-1;
            if(j<=i)
                printf("%c",a[i*(i-1)+j]);
            else
                printf("%c",a[j*(j-1)+i]);
            j=flag_j;
        }
        i=flag_i;
        printf("\n");
    }
}
搜索更多相关主题的帖子: 数字 打印 
2012-05-19 12:38
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:20 
程序代码:
#include<stdio.h>
char cal(int n, int r, int c)
{
    int d;
    if(n - r - 1 < r) r = n - r - 1;
    if(n - c - 1 < c) c = n - c - 1;
    d = (r < c) ? r : c;
    if(d == 0) return 'T';
    if(d == 1) return 'J';
    return d - 1 + '0';
}
int main()
{
    int n, i, j;
    scanf("%d", &n);
    for(i = 0; i < n; i++, putchar('\n'))
    for(j = 0; j < n; putchar(cal(n, i, j++)));
    return 0;
}

重剑无锋,大巧不工
2012-05-19 13:54
飞扬hu
Rank: 2
等 级:论坛游民
帖 子:36
专家分:22
注 册:2011-6-17
收藏
得分:0 
方法挺好的
2012-05-19 14:06
快速回复:求更好的方法
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.051999 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved