c语言 编程显示图案*,*型图案的显示与控制(学习C语言后的编程尝试)(2)(完)...

题目要求如下:

打印如下图案

*

***

*****

*******

*****

***

*

TC中屏幕为25行,80列,将图形放于屏幕中间位置 。按键盘“w”键可以将图(数字,星号皆可)放大,直到最大。按键盘“s”可以把图缩小,直到最小。按“x”可以将图中*变为数字,再按“x“键又将数字变回星号,可以来回反复;数字图形要求:内层为外层数字的和,如354,则输出5;3278则输出8。最外层从1开始。

数字图形也如上可以放大或缩小。按键盘“q”退出。

上次没有写完,也就放下了,这次又拿起来想了想,现在算是完成了。

代码如下:

//显示星号:主要是通过对每行的控制来实现。

#include

#include

#include

#include

#define X 40

#define Y 12

int num[25][80];

char star[25][80];

int flag;

void initialize()

{

int x,y;

for(y=0;y<25;y++)

for(x=0;x<80;x++)

num[y][x]=0;

}

void printStar(int m)

{

int n;

int m1,m2;

int i,j;

int l,k;

n=(m-1)/2;

m1=(m+1)/2;

m2=m-m1;

for(j=0;j

for(i=-j;i

num[Y-n+j][X+i]=1;

for(j=1;j<=m2;j++)

for(i=-(m2-j);i

num[Y+j][X+i]=1;

for(l=0;l<25;l++)

for(k=0;k<80;k++)

{

if(num[l][k]==1)

star[l][k]='*';

else

star[l][k]=' ';

}

for(l=0;l<25;l++)

for(k=0;k<80;k++)

printf("%c",star[l][k]);

initialize();

flag=0;

}

int maxNum(int a)

{

int max=0;

int m;

while(a>0)

{

m=a%10;

if(m>max)

max=m;

a=a/10;

}

return max;

}

void printNum(int m)

{

int n,n1;

int i,j;

int l,k;

int m1,m2;

int sum,sum1,sum2;

int num_=1;

while(m>=1)

{

sum1=sum2=0;

n=(m-1)/2;

m1=(m+1)/2;

m2=m-m1;

j=0;

for(i=0;i

{

num[Y-n+i][X+i]=num_;

num[Y-n+i][X-i]=num_;

sum1=sum1+2*num_;

}

n1=m2-1;

for(j=1;j<=m2;j++)

{

num[Y+j][X+n1]=num_;

num[Y+j][X-n1]=num_;

sum2=sum2+2*num_;

n1--;

}

sum=sum1+sum2-2*num_;

num_=maxNum(sum);

m=m-2;

}

for(l=0;l<25;l++)

for(k=0;k<80;k++)

{

if(num[l][k]==0)

{

star[l][k]=' ';

printf("%c",star[l][k]);

}

else

printf("%d",num[l][k]);

}

initialize();

flag=1;

}

int main()

{

char c;

int s=5;

int l=0;

initialize();

printStar(s);

while(c!='q')

{

c=getche();

if(c=='w')

{

system("cls");

if(flag==0)

{

if(s<25)

{

s=s+2;

printStar(s);

}

else

printStar(25);

}

else

{

if(s<25)

{

s=s+2;

printNum(s);

}

else

printNum(25);

}

}

if(c=='s')

{

system("cls");

if(flag==0)

{

if(s>1)

{

s=s-2;

printStar(s);

}

else

printStar(1);

}

else

{

if(s>1)

{

s=s-2;

printNum(s);

}

else

printNum(1);

}

}

if(c=='x')

{

system("cls");

l++;

if(l%2!=0)

printNum(s);

else

printStar(s);

}

}

return 0;

}

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 53e402bcdef9ce9b54578812dafbf7ce.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值