100个经典C语言程序

发布时间 : 星期一 文章100个经典C语言程序更新完毕开始阅读

ellipse(250,250,0,360,top,bottom); top-=5; bottom+=5; }

getch(); }

============================================================== 【程序64】

题目:利用ellipse and rectangle 画图。 1.程序分析: 2.程序源代码: #include \ #include \ #include \ main() {

int driver=VGA,mode=VGAHI; int i,num=15,top=50; int left=20,right=50;

initgraph(&driver,&mode,\ for(i=0;i

ellipse(250,250,0,360,right,left); ellipse(250,250,0,360,20,top);

rectangle(20-2*i,20-2*i,10*(i+2),10*(i+2)); right+=5; left+=5; top+=10; }

getch(); }

============================================================== 【程序65】

题目:一个最优美的图案。 1.程序分析: 2.程序源代码: #include \ #include \ #include \ #include \ #include \ #include \ #include \ #define MAXPTS 15

#define PI 3.1415926 struct PTS { int x,y; }; double AspectRatio=0.85; void LineToDemo(void) { struct viewporttype vp; struct PTS points[MAXPTS]; int i, j, h, w, xcenter, ycenter; int radius, angle, step; double rads; printf(\ getviewsettings( &vp ); h = vp.bottom - vp.top; w = vp.right - vp.left; xcenter = w / 2; /* Determine the center of circle */ ycenter = h / 2; radius = (h - 30) / (AspectRatio * 2); step = 360 / MAXPTS; /* Determine # of increments */ angle = 0; /* Begin at zero degrees */ for( i=0 ; i

setbkcolor(GREEN); LineToDemo();}

============================================================== 【程序66】

题目:输入3个数a,b,c,按大小顺序输出。 1.程序分析:利用指针方法。 2.程序源代码: /*pointer*/ main() {

int n1,n2,n3;

int *pointer1,*pointer2,*pointer3;

printf(\ scanf(\ pointer1=&n1; pointer2=&n2; pointer3=&n3;

if(n1>n2) swap(pointer1,pointer2); if(n1>n3) swap(pointer1,pointer3); if(n2>n3) swap(pointer2,pointer3);

printf(\ }

swap(p1,p2) int *p1,*p2; {int p;

p=*p1;*p1=*p2;*p2=p; }

============================================================== 【程序67】

题目:输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。

1.程序分析:谭浩强的书中答案有问题。 2.程序源代码: main() {

int number[10]; input(number); max_min(number); output(number); }

input(number)

int number[10]; {int i;

for(i=0;i<9;i++)

scanf(\ scanf(\ }

max_min(array) int array[10];

{int *max,*min,k,l; int *p,*arr_end; arr_end=array+10; max=min=array;

for(p=array+1;p*max) max=p; else if(*p<*min) min=p; k=*max; l=*min;

*p=array[0];array[0]=l;l=*p; *p=array[9];array[9]=k;k=*p; return; }

output(array) int array[10]; { int *p;

for(p=array;p

============================================================== 【程序68】

题目:有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数 1.程序分析: 2.程序源代码: main() {

int number[20],n,m,i;

printf(\ scanf(\ printf(\ scanf(\ for(i=0;i

scanf(\ scanf(\

联系合同范文客服:xxxxx#qq.com(#替换为@)