`

用C打印菱形星号

阅读更多
总结了一下:

//这是做简单的,不考虑任何算法,傻X
#include <stdio.h>
int main()
{
printf("   *\n ***\n *****\n*******\n *****\n ***\n   *\n");
}

最简短的程序估计就是这个了
//C版本的:
#include <stdio.h>
int main()
{
        int i = 0;
        for (; i < 9; i ++)
        {
            printf("%*s\n",((i < 5) ? (i + 5) : (13 - i)),"*********" + ((i < 5) ? (8 - 2*i) : (2*i - 8)));
        }
        return 0;
}

//C++版本的:
#include <iostream>
using namespace std;
int main()
{
     for (int i = 0; i < 9; i ++)
     {

      cout << "    " + ((i < 5) ? i : (8 - i))<< "*********" + ((i < 5) ? (8 - 2*i) : (2*i - 8)) << endl;
        }
        return 0;
}

//双重嵌套再循环
#include <stdio.h>
#include <math.h>
void main()
{
    int n,i,j;
    printf("n=");
    scanf("%d",&n);
    for(i=0;i<(n*2+1);i++)
    {
        for(j=0;j<fabs(i-n);j++) printf(" ");
        for(j=0;j<(2*(n-fabs(i-n))+1);j++) printf("*");
        printf("\n");
    }
}

//再来,统一求和判断,不分上下
#include<stdio.h>
void main()
{
    int i,j,n;
    printf("n=?\n");
    scanf("%d",&n);
    for(i=0; i<2*n+1; i++)
    {
        for(j=0; j<2*n+1; j++)
        {
            if( i+j>=n && i+j<=3*n && i-j>=-n && i-j<=n ) printf("*");
            else printf(" ");
        }
        printf("\n");
    }
}

//正负判断方法
#include<stdio.h>
#include<math.h>
#define N 5
void main()
{
    int i,j;
    for(i=-N;i<=N;i++)
    {
        for(j=-N;j<=N;j++)
        {
            if(abs(i)+abs(j)<=N)
                printf("*");
            else
                printf(" ");
        }
        printf("\n");
     }

   getchar();
}
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics