首页 > 其他 > 详细

队列堆栈和数组-三角矩阵

时间:2014-09-26 21:02:59      阅读:301      评论:0      收藏:0      [点我收藏+]
#include<iostream>
#include <iomanip>
using namespace std;
enum TriangleTye{leftBottom,leftUp,rightBottom,rightUp};
struct TriangleMatrix
{
    int* nums;
    int scale;
    TriangleTye triangleTye;
    int size;
};

TriangleMatrix* createTriangleMatrix(int scale,TriangleTye triangleTye)
{
    int size = scale*(scale+1)/2;
    TriangleMatrix* p = (TriangleMatrix*)malloc(sizeof(TriangleMatrix));
    p->nums = new int[size+1];
    p->scale=scale;
    p->triangleTye=triangleTye;
    p->size=size;
    return p;
}

int getElement(TriangleMatrix* matrix,int i,int j)
{
    switch ((matrix->triangleTye))
    {
    case leftBottom:
        if(i<j)
            return 0;
        else return matrix->nums[i*(i-1)/2+j-1];
        break;

    case leftUp:
        if(matrix->scale-i+1<j)
            return 0;
        else return matrix->nums[matrix->size - ((matrix->scale-i)*(matrix->scale-i+1)/2+(matrix->scale-i+1-j))-1];
        break;

    case rightBottom:
        if(matrix->scale-i+1>j)
            return 0;
        else return matrix->nums[i*(i-1)/2+j-(matrix->scale-i)-1];
        break;

    case rightUp:
        if(i>j)
            return 0;
        else  return matrix->nums[matrix->size - (matrix->scale-i+1)*(matrix->scale-i+2)/2+j-i];
        break;

    default:
        return -1;
        break;
    }
}

void OuptPut(TriangleMatrix* p)
{
    
    for(int i=1;i<=p->scale;i++)
    {
        for(int j=1;j<=p->scale;j++)
        {
            printf("%d ",getElement(p,i,j)); 
        }
        printf("\n"); 
    }
}

void main()
{
    printf("\n"); 
    printf("%s","four kinds of triangle matrix, and the elements is:"); 
    printf("\n"); 
    int x=9;
    TriangleMatrix* p= createTriangleMatrix(x,leftBottom);
    for(int i=0;i<x*(x+1)/2;i++)
    {
        p->nums[i]=rand()%10;
        printf("%d ",p->nums[i]); 
    }
     printf("\n"); 
     printf("vertical corner at leftBottom:\n"); 
     OuptPut(p);

     printf("vertical corner at rightBottom:\n"); 
     p->triangleTye = rightBottom;
     OuptPut(p);

     printf("vertical corner at leftUp:\n"); 
     p->triangleTye = leftUp;
     OuptPut(p);

    printf("vertical corner at rightUp:\n"); 
     p->triangleTye = rightUp;
     OuptPut(p);

    printf("Done\n"); 
    scanf("%d",&x);
}

 

队列堆栈和数组-三角矩阵

原文:http://www.cnblogs.com/kbyd/p/3995500.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!