.
#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 ; irads = (double)angle * pi / 180.0; /* convert angle to radians */ points[i].x = xcenter + (int)( cos(rads) * radius );
points[i].y = ycenter - (int)( sin(rads) * radius * aspectratio ); angle += step; /* move to next increment */ }
circle( xcenter, ycenter, radius ); /* draw bounding circle */
for( i=0 ; ifor( j=i ; jmoveto(points[i].x, points[i].y); /* move to beginning of cord */ lineto(points[j].x, points[j].y); /* draw the cord */ } } } main()
{int driver,mode;
driver=cga;mode=cgac0; initgraph(&driver,&mode,\setcolor(3);
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 if(*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 printf(\printf(\}
==============================================================
【程序68】
题目:有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数
1.程序分析: 2.程序源代码: main() {
int number[20],n,m,i;
printf(\scanf(\printf(\scanf(\
for(i=0;i scanf(\scanf(\move(number,n,m);
for(i=0;i printf(\printf(\}
move(array,n,m) int n,m,array[20]; {
int *p,array_end;
array_end=*(array+n-1);
for(p=array+n-1;p>array;p--) *p=*(p-1);
*array=array_end; m--;
.
.
if(m>0) move(array,n,m); }
==============================================================
【程序69】
题目:有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出
圈子,问最后留下的是原来第几号的那位。 1. 程序分析: 2.程序源代码: #define nmax 50 main() {
int i,k,m,n,num[nmax],*p;
printf(\scanf(\p=num;
for(i=0;i *(p+i)=i+1; i=0; k=0; m=0;
while(m {
if(*(p+i)!=0) k++; if(k==3) { *(p+i)=0; k=0; m++; } i++;
if(i==n) i=0; }
while(*p==0) p++; printf(\}
==============================================================
【程序70】
题目:写一个函数,求一个字符串的长度,在main函数中输入字符串,并输出其长度。 1.程序分析: 2.程序源代码: main() {
int len;
char *str[20];
.