经典c程序设计100例

/*
题目:宏#define命令练习(1) 
*/
#include "stdio.h"
#include "conio.h"
#define TRUE 1
#define FALSE 0
#define SQ(x) (x)*(x)//有参宏
int main()
{
	int num;
	int again=1;
	printf("\40: Program will stop if input value less than 50.\n");
	while(again)
	{
		printf("\40:Please input number==>");
		scanf("%d",&num);
		printf("\40:The square for this number is %d \n",SQ(num));
		if(num>=50)
		again=TRUE;
		else
		again=FALSE;
	}
	getch();
	return 0;
}
/*
题目:宏#define命令练习(2)
*/
#include "stdio.h"
#include "conio.h"
/*
宏定义中允许包含两道衣裳命令的情形,此时必须在最右边加上"\"。
(这是作者的笔误,正确的应该是宏定义中允许包含俩行以上的命令,也就是说两行以上命令组成的一个宏定义需要用\来进行连接)
*/
#define exchange(a,b) { \
	int t;\
	t=a;\
	a=b;\
	b=t;\
}
int main(void)
{
	int x=10;
	int y=20;
	printf("x=%d; y=%d\n",x,y);
	exchange(x,y);
	printf("x=%d; y=%d\n",x,y);
	getch();
	return 0;
}

/*
题目:宏#define命令练习(3)   
*/
#include "stdio.h"
#include "conio.h"
#define LAG >
#define SMA <
#define EQ ==
int main(void)
{
	int i=10;
	int j=20;
	if(i LAG j)
		printf("\40: %d larger than %d \n",i,j);
	else if(i EQ j)
		printf("\40: %d equal to %d \n",i,j);
	else if(i SMA j)
		printf("\40:%d smaller than %d \n",i,j);
	else
		printf("\40: No such value.\n");
	getch();
	return 0;
}

/*
题目:#if #ifdef和#ifndef的综合应用。
*/
#include "stdio.h"
#include "conio.h"
#define MAX
#define MAXIMUM(x,y) (x>y)?x:y
#define MINIMUM(x,y) (x>y)?y:x
int main()
{
	int a=10,b=20;
	//条件编译,在满足某种条件时才编译
	#ifdef MAX
		printf("\40: The larger one is %d\n",MAXIMUM(a,b));//若定义了MAX执行该语句
	#else
		printf("\40: The lower one is %d\n",MINIMUM(a,b));//没有定义MAX则执行此语句
	#endif//结束条件编译

	#ifndef MIN
		printf("\40: The lower one is %d\n",MINIMUM(a,b));
	#else
		printf("\40: The larger one is %d\n",MAXIMUM(a,b));
	#endif

	#undef MAX//此语句一下MAX的定义已经无效

	#ifdef MAX
		printf("\40: The larger one is %d\n",MAXIMUM(a,b));
	#else
		printf("\40: The lower one is %d\n",MINIMUM(a,b));
	#endif

	#define MIN

	#ifndef MIN
		printf("\40: The lower one is %d\n",MINIMUM(a,b));
	#else
		printf("\40: The larger one is %d\n",MAXIMUM(a,b));
	#endif
	getch();
	return 0;
}

/*
题目:#include 的应用练习   
*/

/*
test.h 文件如下:
#define LAG >
#define SMA <
#define EQ ==
*/
#include "test.h" /*一个新文件50.c,包含test.h*/
#include "stdio.h"
#include "conio.h"
int main(void)
{
	int i=10;
	int j=20;
	if(i LAG j)
		printf("\40: %d larger than %d \n",i,j);
	else if(i EQ j)
		printf("\40: %d equal to %d \n",i,j);
	else if(i SMA j)
		printf("\40:%d smaller than %d \n",i,j);
	else
		printf("\40: No such value.\n");
	getch();
	return 0;
}

题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
*/
#include <stdio.h>
int main()
{
	int arr[4]={1,2,3,4};
	int i,j,k,count=0;
	int value[64];
	for(i=0;i<4;i++)
	{
		for(j=0;j<4;j++)
		{
			if(j==i)
				continue;
			for(k=0;k<4;k++)
			{
				if(k==j || k==i)
					continue;
				value[count]=arr[i]*100+arr[j]*10+arr[k];
				count++;
			}
		}
	}
	printf("这样的数共有%d个,他们分别是:\n",count);
	for(i=0;i<count;i++)
	{
		printf("%5d",value[i]);
	}
	return 0;
}


 

/*
题目:企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高
于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提
成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于
40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于
100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?
*/
#include <stdio.h>
int main()
{
	long i;
	int sum=0;
	printf("请输入当月的利润:\n");
	scanf("%ld",&i);
	if(i>1000000)
	{
		sum=(i-1000000)*0.01+100000*0.1+100000*(7.5/100)+200000*0.05+200000*0.03+400000*(1.5/100);
	}
	else if(i<=1000000 && i>600000)
	{
		sum=(i-600000)*(1.5/100)+100000*0.1+100000*(7.5/100)+200000*0.05+200000*0.03;
	}
	else if(i<=600000 && i>400000)
	{
		sum=(i-400000)*0.03+100000*0.1+100000*(7.5/100)+200000*0.05;
	}
	else if(i<=400000 && i>200000)
	{
		sum=(i-200000)*0.05+100000*0.1+100000*(7.5/100);
	}
	else if(i<=200000 && i>100000)
	{
		sum=(i-100000)*(7.5/100)+100000*0.1;
	}
	else if(i<=100000)
	{
		sum=i*0.1;
	}
	printf("本月应该发放的奖金为:%d元\n",sum);
	getch();
	return 0;
}


 

/*
题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
用到的函数:sqrt();
函数原型: 在VC6.0中的math.h头文件的函数原型为double sqrt(double); 
*/
#include <stdio.h>
#include <math.h>
int isSqrt(double i)
{
	int n;
	n=sqrt(i);
	if(n*n==i)
		return 1;
	return 0;
}
int main()
{
	int i=1;
	while(!isSqrt(i+100) || !isSqrt(i+168))
		i++;
	printf("这个数是:%d\n",i);
	getch();
	return 0;
}


 

/*
题目:输入某年某月某日,判断这一天是这一年的第几天?
*/
#include <stdio.h>
int main()
{
	int year,month,day;
	int value;
	int tem=28;//存放二月的天数
	printf("请输入某年某月某日:\n");
	scanf("%d.%d.%d",&year,&month,&day);
	if((year%4==0 && year%100!=0) || (year%400==0))
		tem=29;
	switch(month)
	{
	case 1:
		value=day;
		break;
	case 2:
		value=31+day;
		break;
	case 3:
		value=31+tem+day;
		break;
	case 4:
		value=31+tem+31+day;
		break;
	case 5:
		value=31+tem+31+30+day;
		break;
	case 6:
		value=31+tem+31+30+31+day;
		break;
	case 7:
		value=31+tem+31+30+31+30+day;
		break;
	case 8:
		value=31+tem+31+30+31+30+31+day;
		break;
	case 9:
		value=31+tem+31+30+31+30+31+31+day;
		break;
	case 10:
		value=31+tem+31+30+31+30+31+31+30+day;
		break;
	case 11:
		value=31+tem+31+30+31+30+31+31+30+31+day;
		break;
	case 12:
		value=31+tem+31+30+31+30+31+31+30+31+30+day;
		break;
	default :
		printf("您的输入不合法!\n");
		return;
	}
	printf("这一天是这一年的第%d天。\n",value);
	getch();
	return 0;
}


 

/*
题目:输入三个整数x,y,z,请把这三个数由小到大输出.
*/
#include <stdio.h>
int main()
{
	int x,y,z,tem;
	printf("请输入三个整数:\n");
	scanf("%d%d%d",&x,&y,&z);
	if(x<y)
	{
		tem=x;
		x=y;
		y=tem;
	}
	if(x<z)
	{
		tem=x;
		x=z;
		z=tem;
	}
	if(y<z)
	{
		tem=y;
		y=z;
		z=tem;
	}
	printf("这三个数的大小顺序为:%d %d %d\n",z,y,x);
	getch();
	return 0;
}


 

/*
题目:用*号输出字母C的图案。
*/
#include <stdio.h>
int main()
{
	printf("\tHello C-world!\n");
	printf(" \t****\n");
	printf(" \t*\n");
	printf(" \t* \n");
	printf(" \t****\n");
	getch(); 
	return 0;
}

/*
题目:输出特殊图案,请在c环境中运行,看一看,Very Beautiful!
这道题是贴的,本人实在不知道它想干什么。
*/
#include <stdio.h>
int main()
{
	char a=176,b=219;
	printf("%c%c%c%c%c\n",b,a,a,a,b);
	printf("%c%c%c%c%c\n",a,b,a,b,a);
	printf("%c%c%c%c%c\n",a,a,b,a,a);
	printf("%c%c%c%c%c\n",a,b,a,b,a);
	printf("%c%c%c%c%c\n",b,a,a,a,b);
	getch(); 
	return 0;
}

/*
题目:输出9*9口诀。
*/
#include <stdio.h>
int main()
{
	int i,j;
	for(i=1;i<10;i++)
	{
		for(j=1;j<i+1;j++)
		{
			printf("%d*%d=%d\t",j,i,i*j);
		}
		printf("\n");
	}
	getch();
	return 0;
}

/*
题目:要求输出国际象棋棋盘。
没见过国际象棋棋盘,代码贴了上来。也没看懂什么东西。
*/
#include "stdio.h"
#include "conio.h"
int main()
{
	int i,j;
	for(i=0;i<8;i++)
	{
		for(j=0;j<8;j++)
			if((i+j)%2==0)
				printf("%c%c",219,219);
			else
				printf(" ");
		printf("\n");
	}
	getch(); 
	return 0;
}

/*
题目:打印楼梯,同时在楼梯上方打印两个笑脸。 
*/
#include "stdio.h"
int main()
{
	int i,j;
	printf("\1\1\n"); /*\1是八进制表示,代表十进制的64,字符是@*/
	for(i=1;i<11;i++)
	{
		for(j=1;j<=i;j++)
			printf("%c%c",219,219);	
		printf("\n");
	}
	getch();
	return 0; 
}
/*
题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月
后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
每个月兔子数的规律为:1,1,2,3,5,8,13,21....即fn=f(n-1)+f(n-2),f1=1,f2=1,求fn.
*/
#include <stdio.h>
int main()
{
	int i;
	int f1=1,f2=1;
	int fn_1=f2,fn_2=f1,fn=fn_1+fn_2;
	int month;
	printf("你想知道第几个月的兔子数:\n");
	scanf("%d",&month);
	if(month==1 || month==2)
	{
		fn=1;
	}
	i=4;
	while(i<=month)
	{
		fn_2=fn_1;
		fn_1=fn;
		fn=fn_1+fn_2;
		i++;
	}
	printf("这个月的兔子总数为:%d\n",fn);
	getch();
	return 0;
}

/*
题目:判断101-200之间有多少个素数,并输出所有素数。
*/
#include <stdio.h>
#include <math.h>
int main()
{
	int i,j,k;
	int count=0;
	printf("101-200之间的素数为:\n");
	for(i=101;i<200;i++)
	{
		k=sqrt(i);
		for(j=2;j<k+1;j++)
		{
			if(i%j==0)
				break;
		}
		if(j==k+1)
		{
			printf("%5d",i);
			count++;
		}
	}
	printf("\n共有%d个。\n",count);
	getch();
	return 0;
}

/*
题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数
本身。例如:153是一个“水仙花数”,因为153= 1的三次方+5的三次方+3的三次方。 
*/
#include <stdio.h>
int main()
{
	int i,j;
	int gw,sw,bw;
	printf("所有的水仙花数为:\n");
	for(i=100;i<1000;i++)
	{
		gw=i%10;
		sw=i/10%10;
		bw=i/100;
		if((gw*gw*gw+sw*sw*sw+bw*bw*bw)==i)
			printf("%5d",i);
	}
	printf("\n");
	getch();
	return 0;
}

/*
题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。
*/
#include <stdio.h>
int main()
{
	int n;
	int i,j;
	printf("请输入一个正整数:\n");
	scanf("%d",&n);
	printf("%d=",n);
	for(i=2;i<n;i++)
	{
		if(n%i==0)
		{
			printf("%d*",i);
			n=n/i;
			i=2;
		}
	}
	printf("%d\n",n);
	getch();
	return 0;
}

/*
题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,
60分以下的用C表示。
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int score;
	char a;
	printf("请输入考试分数:\n");
	scanf("%d",&score);
	a= score>=90 ? 'A' : (score>60 ? 'B' : 'C');
	printf("成绩等级为:%c\n",a);
	getch();
	return 0;
}


/*
题目:输入两个正整数m和n,求其最大公约数和最小公倍数
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int a,b,tem;
	int r;
	int i,j;
	printf("请输入俩个正整数:\n");
	scanf("%d%d",&a,&b);
	if(a<b)
	{
		tem=a;
		a=b;
		b=tem;
	}
	//将俩个原数保存下来
	i=a;
	j=b;
	//俩个数的最大公约数等于较小的数与这俩个数的模数的最大公约数
	r=a%b;
	if(r!=0)
	{
		a=b;
		b=r;
		r=a%b;
	}
	//此时b中存放的是a和b的最大公约数
	//俩个数的最小公倍数等于这俩个数的乘积与最大公约数的比
	printf("这俩个数的最大公约数是:%d\n最小公倍数是:%d\n",b,i*j/b);
	getch();
	return 0;
}

/*
题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。
*/
#include <stdio.h>
#include <conio.h>
#include <string.h>
int main()
{
	int ecount=0,scount=0,ncount=0,ocount=0;
	int i,len;
	char arr[30];
	char a;
	printf("请输入一行字符串(字符数小于30个):\n");
	gets(arr);
	len=strlen(arr);
	for(i=0;i<len;i++)
	{
		a=arr[i];
		if(isalpha(a))
			ecount++;
		else if(a==' ')
			scount++;
		else if(a>='0' && a<='9')
			ncount++;
		else
			ocount++;
	}
	printf("英文字母的个数为:%d\n空格的个数为:%d\n数字的个数为:%d\n其他字符的个数为:%d\n ",ecount,scount,ncount,ocount);
	getch();
	return 0;
}

/*
题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如2+22+222+2222+22222(此时
共有5个数相加),几个数相加有键盘控制。 
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int a,n;
	long sum=0,sub=0;
	int i,aa;
	printf("请输入数字a以及你希望相加的数的个数:\n");
	scanf("%d%d",&a,&n);
	aa=a;
	for(i=0;i<n;i++)
	{
		sub+=a;
		sum+=sub;
		a=a*10;
	}
	printf("s=%ld\n",sum);
	getch();
	return 0;
}

/*
题目:一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程
找出1000以内的所有完数。 
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int i,j;
	int sum;
	printf("1000以内所有的完数如下:\n");
	for(i=2;i<1000;i++)
	{
		sum=0;
		for(j=1;j<i;j++)
		{
			if(i%j==0)
			{
				sum+=j;
			}
		}
		if(sum==i)
		{
			printf("%5d",i);
		}
	}
	printf("\n");
	getch();
	return 0;
}

/*
题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在
第10次落地时,共经过多少米?第10次反弹多高? 
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int i;
	double sum=0.0;
	double height=100.0;
	sum=height;
	for(i=2;i<11;i++)
	{
		height/=2;
		sum+=height*2;
	}
	height/=2;
	printf("它在第10次落地时,共经过%.3lf米,第10次反弹%.3lf米高\n",sum,height);
	getch();
	return 0;
}
/*
题目:猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个
第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下
的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int sum=1;
	int i;
	for(i=10;i>1;i--)
	{
		sum=(sum+1)*2;
	}
	printf("第一天共摘了%d个桃!\n",sum);
	getch();
	return 0;
}



/*
题目:两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定
比赛名单。有人向队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出 
三队赛手的名单。 
*/
#include "stdio.h"
#include "conio.h"
int main()
{
	char a,b,c;
	for(a='x';a<='z';a++)
	{
		for(b='x';b<='z';b++)
		{
			if(a!=b)
			{
				for(c='x';c<='z';c++)
				{
					if(a!=c && b!=c)
					{
						if(a!='x' && c!='x' && c!='z')
						{
							printf("order is a--%c\tb--%c\tc--%c\n",a,b,c);
						}
					}
				}
			}
		}
	}
	getch();
	return 0;
}

/*

题目:打印出如下图案(菱形)
*
***
*****
*******
*****
***
*

*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int i,j;//i用来控制行数,j用来控制列数
	for(i=1;i<5;i++)
	{
		j=1;
		while(j<=2*i-1)
		{
			printf("*");
			j++;
		}
		printf("\n");
	}
	for(i=3;i>0;i--)
	{
		j=2*i-1;
		while(j>0)
		{
			printf("*");
			j--;
		}
		printf("\n");
	}
	return 0;
}

/*
题目:有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列的前20项之和。
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int i;
	float x1,x2,x3,y1,y2,y3;
	float sum;
	x1=1.0,x2=2.0,x3=x1+x2;
	y1=2.0,y2=3.0,y3=y1+y2;
	sum=(y1/x1)+(y2/x2)+(y3/x3);
	for(i=4;i<21;i++)
	{
		x1=x2;
		x2=x3;
		x3=x1+x2;
		y1=y2;
		y2=y3;
		y3=y1+y2;
		sum += y3/x3;
	}
	printf("该数列的前20项之和为:%f\n",sum);
	getch();
	return 0;
}


/*
题目:求1+2!+3!+...+20!的和
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	float sum=0.0;
	float value=1.0;//注意精度的问题
	int i,j;
	for(i=1;i<21;i++)
	{
		for(j=i;j>0;j--)
		{
			value*=j;
		}
		sum+=value;
		value=1;
	}
	printf("1+2!+3!+...+20!的和为:%e\n",sum);
	getch();
	return 0;
}

/*
题目:利用递归方法求5!。
*/
#include <stdio.h>
#include <conio.h>
int method(int);
int main()
{
	int i;
	i=method(5);
	printf("5!的值为:%d\n",i);
	getch();
	return 0;
}
int method(int n)
{
	if(n==1)
		return n;
	else
	{
		return n*method(n-1);
	}
}

/*
题目:利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。
*/
#include <stdio.h>
#include <conio.h>
#include <string.h>
void method(char *arr);
int main()
{
	char arr[6];
	printf("请输入五个字符:\n");
	gets(arr);
	method(arr);
	getch();
	return 0;
}
void method(char *arr)
{
	char a;
	a=arr[0];
	if(strlen(arr)==0)
	{
		return;
	}
	else
	{
		method(++arr);
		putchar(a);
	}
}

/*
题目:有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第
3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后 
问第一个人,他说是10岁。请问第五个人多大?
*/
#include "stdio.h"
#include "conio.h"
main()
{
	int i,j=10;
	for(i=1;i<5;i++)
	{
		j+=2;
	}
	printf("第五个人%d岁",j);
	getch();
	return 0;
}

/*
题目:给一个不多于5位的正整数,要求:一、求它是几位数,二、逆序打印出各位数字。
*/
#include <stdio.h>
#include <conio.h>
#include <math.h>
int main(void)
{
	int n;
	int gw,sw,bw,qw,ww;
	int len=5;
	int arr[5];
	int i;
	printf("请输入一个不多于5位的正整数\n");
	scanf("%d",&n);
	arr[0]=gw=n%10;
	arr[1]=sw=n%100/10;
	arr[2]=bw=n%1000/100;
	arr[3]=qw=n%10000/1000;
	arr[4]=ww=n/10000;
	for(i=4;i>0;i--)
	{
		if(arr[i]==0)
		{
			len=i;
		}
	}
	n=0;
	for(i=0;i<len;i++)
	{
		n+=arr[i]*(int)pow(10,len-i-1);
	}
	printf("该数字是%d位数,逆序后的数字为:%d\n",len,n);
	getch();
	return 0;
}

/*
题目:一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。
*/
#include <stdio.h>
#include <conio.h>
#include <math.h>
int main(void)
{
	int n,m=0;
	int gw,sw,bw,qw,ww;
	int len=5;
	int arr[5];
	int i;
	printf("请输入一个不超过5位的正整数\n");
	scanf("%d",&n);
	arr[0]=gw=n%10;
	arr[1]=sw=n%100/10;
	arr[2]=bw=n%1000/100;
	arr[3]=qw=n%10000/1000;
	arr[4]=ww=n/10000;
	for(i=4;i>0;i--)
	{
		if(arr[i]==0)
		{
			len=i;
		}
	}
	for(i=0;i<len;i++)
	{
		m+=arr[i]*(int)pow(10,len-i-1);
	}
	if(m==n)
	{
		printf("n=%d\nm=%d\n故数字%d是回文数\n",n,m,n);
	}
	else
	{
		printf("n=%d\nm=%d\n故数字%d不是回文数\n",n,m,n);
	}
	getch();
	return 0;
}

/*
题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续
判断第二个字母。
*/
#include <stdio.h>
#include <conio.h>
int main(void)
{
	char a,b;
	printf("请输入星期的首字母:\n");
	scanf("%c",&a);
	getchar();
	if(a=='s')
	{
		printf("请输入第二个字母:\n");
		scanf("%c",&b);
		if(b=='a')
		{
			printf("Saturday\n");
			return;
		}
		else if(b=='u')
		{
			printf("Sunday\n");
			return;
		}
		else
		{
			printf("无匹配星期\n");
			return;
		}
	}
	else if(a=='t')
	{
		printf("请输入第二个字母:\n");
		scanf("%c",&b);
		if(b=='u')
		{
			printf("Tuesday\n");
			return;
		}
		else if(b=='h')
		{
			printf("Thursday\n");
			return;
		}
		else
		{
			printf("无匹配星期\n");
			return;
		}
	}
	switch(a)
	{
	case 'm':
		printf("Monday\n");
		break;
	case 'w':
		printf("Wednesday\n");
		break;
	case 'f':
		printf("Friday\n");
		break;
	default :
		printf("无匹配星期\n");
		break;
	}
	getch();
	return 0;
}
/*
题目:Press any key to change color, do you want to try it. Please hurry up!
本文件包含的textbackground()函数在vc库中不包含,编译只能在tuberc中。
*/
#include "conio.h"
#include "stdio.h"
int main(void)
{
	int color;
	for (color = 0; color < 8; color++)
	{ 
		textbackground(color);/*设置文本的背景颜色*/
		cprintf("This is color %d\r\n", color);
		cprintf("Press any key to continue\r\n");
		getch();/*输入字符看不见*/
	}
	return 0;
	getch();
}

/*
题目:学习gotoxy()与clrscr()函数*/
#include "conio.h"
#include "stdio.h"
void main(void)
{
	clrscr();/*清屏函数*/
	textbackground(2);
	gotoxy(1, 5);/*定位函数,将光标的位置定位到(1,5)这个坐标*/
	cprintf("Output at row 5 column 1\n");
	textbackground(3);
	gotoxy(20, 10);
	cprintf("Output at row 10 column 20\n");
	getch();
}

/*
画个猪头!
*/
#include <stdio.h>
#include <windows.h>
int main (void)
{ 
	for(;;) 
	{  
		printf ("  ╭︿︿︿╮\n");  
		Sleep(500); 
		printf (" { / ·  · /} \n");  
		Sleep(500);  
		printf ("   ( (00) ) \n");   
		Sleep(500);  
		printf ("    ︶︶︶\n");   
		Sleep(500);  
		system ("cls");
		Sleep(500); 
	} 
	return 0; 
}

/*
题目:文本颜色设置
*/
#include "stdio.h"
#include "conio.h"
void main(void)
{
	int color;
	for (color = 1; color < 16; color++)
	{
		textcolor(color);/*设置文本颜色*/
		cprintf("This is color %d\r\n", color);
	}
	textcolor(128 + 15);
	cprintf("This is blinking\r\n");
	getch();
}

/*
题目:求100之内的素数
*/
//方法1 利用筛法查找质数(素数) 
#include "stdio.h"
#include "math.h"
int main()
{
	int a[100];
	int i,newp;
	//在数组中加入一百个数 
	for(i=0;i<100;i++)
	{
		a[i]=i+1;
	}
	//将所有不是质数的数置为零,1不是质数将其置为0。
	a[0]=0;
	//质数的倍数一定不为质数,在数字2-sqrt(n)(sqrt(n)函数的作用是求n的开方数)的范围内找出所有质数的倍数将其置为0
	for(newp=1;a[newp]<sqrt(100);newp++)
	{
		//判断其是否为质数
		if(a[newp]!=0)
		{
			//从该质数的后一个数判断是否为该质数的倍数 
			i=newp+1;
			while(a[i]<101)
			{
				if(a[i]%a[newp]==0)
				{
					a[i]=0;//将该质数的倍数置为0 
				}
				i++;
			}
		}
	}
	//打印所有的质数 
	for(i=0;i<100;i++)
	{
		if(a[i]!=0)
			printf("%5d",a[i]);
	}
	return 0;
}

//方法2:这种方法比较简单,就是看2到该数减去1之内的数能否被该数整除
#include "stdio.h"
int main()
{
	int a[100];
	int i,j,flag;
	for(i=0;i<100;i++)
	{
		a[i]=i+1;
	}
	//取出2-a[99]中的数进行判断 
	for(i=1;a[i]<101;i++)
	{
		flag=1;
		for(j=2;j<a[i];j++)
		{
			if(a[i]%j==0)
			{
				flag=0;
				break;
			} 
		}
		if(flag==1)
		{
			printf("%5d",a[i]);
		}
	} 
	return 0;
} 

//方法3 与方法2不同的是看2到该数的开方数范围内的数能否被该数整除

#include "stdio.h"
#include "math.h"
int main()
{
	int a[100];
	int i,j,t;
	for(i=0;i<100;i++)
	{
		a[i]=i+1;
	}
	for(i=1;i<100;i++)
	{
		t=sqrt(a[i]);
		for(j=2;j<t+1;j++)
		{
			if(a[i]%j==0)
				break;
		}
		if(j==t+1)
			printf("%5d",a[i]);
	}
	return 0;
}

/*
题目:对10个数进行排序
*/
#include <stdio.h>
#include <conio.h>
void quick_Sort(int a[],int low,int high);
int main()
{
	int a[10];
	int i;
	printf("please enter ten int number:\n");
	for(i=0;i<10;i++)
	{
		scanf("%d",&a[i]);
	}
	quick_Sort(a,0,9);
	printf("after sorted:\n");
	for(i=0;i<10;i++)
	{
		printf("%5d",a[i]);
	}
	getch();
	return 0;
}

//快速排序的原理是选择一个数作为分界点,将小于他的数放到他的左边,大于他的数放到他的右边,然后分别对左右俩边的数进行同样方法的处理,得出结果

void quick_Sort(int a[],int low,int high)  
{  
    int pos;  
    if(low<high)  
    {  
		//确定一个位置pos,pos左边的数都比pos位置上的数小,pos右边的数都比pos位置上的数大
        pos=findpos(a,low,high);  
        quick_Sort(a,low,pos-1);  
        quick_Sort(a,pos+1,high);  
    }  
}

//该方法的作用是返回一个位置值,使得该位置左边的数都比该位置上的数小,该位置右边的数都比该位置上的数大  

int findpos(int a[],int low,int high)  
{  
	//假定数组中的数为49,38,65,13,50之后便于进行说明
	//从数组中选择一个数作为分界点,该数为49
    int val=a[low];  
    while(low<high)  
    {
		//指针从high开始,将其值(即50)与val进行比较,若大于val,就移动high指针向前,再次比较,若小于val的值就将该值覆盖low指针位置处的值
        while(low<high && a[high]>val)  
            high--;  
        a[low]=a[high];  
		//程序执行到这里后数列的排列顺序为13,38,65,13,50,此时low和high指针的位置并没有互换
		//指针从low开始,将其值(即13)与val进行比较,若小于val,就移动low指针向后,再次比较,若大于val的值就将该值覆盖high指针位置处的值
        while(low<high && a[low]<val)  
            low++;  
        a[high]=a[low];  
		//程序执行到这里后数列的排列顺序为13,38,65,65,50,此时满足low小于high,进行下一次的循环
    }  
    a[low]=val;//移动完毕low和high必定相等,此时的数列排列顺序为13,38,49,65,50,low=high=3 于是使得49左边的数都比49小,49右边的数都比49大   
    return low;  
}

/*
题目:求一个3*3矩阵对角线元素之和 
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int a[3][3];
	int i,j,sum=0;
	printf("请输入一个三乘三的矩阵:\n");
	for(i=0;i<3;i++)
	{
		for(j=0;j<3;j++)
		{
			scanf("%d",&a[i][j]);
			if(i==j)
			{
				sum+=a[i][j];
			}
		}
	}
	printf("该矩阵的对角线元素之和为%d\n",sum);
	getch();
	return 0;
}

/*题目:有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。
*/
#include "stdio.h"
#include "conio.h"
int main(void)
{
	int a[11]={1,4,6,9,13,16,19,28,40,100};
	int i,number;
	int tem;
	int j;
	printf("original array is:\n");
	for(i=0;i<10;i++)
	{
		printf("%5d",a[i]);
	}
	printf("\n");
	printf("insert a new number:");
	scanf("%d",&number);
	if(a[0]>=number)
	{
		a[10]=a[9];
		for(i=8;i>-1;i--)
		{
			a[i+1]=a[i];
		}
		a[0]=number;
	}
	else
	{
		for(i=1;i<10;i++)
		{
			if(a[i]>=number)
			{
				a[10]=a[9];
				for(j=8;j>i-1;j--)
				{
					a[j+1]=a[j];
				}
				a[i]=number;
				break;
			}
		}
	}
	printf("after inserted array is:\n");
	for(i=0;i<11;i++)
	{
		printf("%5d",a[i]);
	}
	printf("\n");
	getch();
	return 0;
}

/*
题目:将一个数组逆序输出。
*/
#include <stdio.h>
#include <conio.h>
int main(void)
{
	int i,tem;
	int a[10]={0,1,2,3,4,5,6,7,8,9};
	printf("original array is:\n");
	for(i=0;i<10;i++)
	{
		printf("%5d",a[i]);
	}
	printf("\n");
	for(i=0;i<5;i++)
	{
		tem=a[i];
		a[i]=a[9-i];
		a[9-i]=tem;
	}
	printf("after reverse the array is:\n");
	for(i=0;i<10;i++)
	{
		printf("%5d",a[i]);
	}
	printf("\n");
	getch();
	return 0;
}

/*
题目:学习static定义静态变量的用法
*/
#include <stdio.h>
#include <conio.h>
void varfunc()
{
	int var=0;
	static int static_var=0;
	printf("\40:var equal %d \n",var);
	printf("\40:static var equal %d \n",static_var);
	printf("\n");
	var++;
	static_var++;
}
int main(void)
{
	int i;
	for(i=0;i<3;i++)
	varfunc();
	getch();
	return 0;
}

/*
题目:学习使用auto定义变量的用法
*/
#include "stdio.h"
#include "conio.h"
int main(void)
{
	int i,num;
	num=2;
	for(i=0;i<3;i++)
	{
		printf("\40: The num equal %d \n",num);
		num++;
		//代码块中含有num的定义,打印的时候对num的引用是里边的num
		{
			auto int num=1;
			printf("\40: The internal block num equal %d \n",num);
			num++;
		}
	}
	getch();
	return 0;
}

/*
题目:学习使用static的另一用法
*/
#include "stdio.h"
#include "conio.h"
int main(void)
{
	int i,num;
	num=2;
	for(i=0;i<3;i++)
	{
		printf("\40: The num equal %d \n",num);
		num++;
		{
			static int num=1;
			printf("\40:The internal block num equal %d\n",num);
			num++;
		}
	}
	getch();
	return 0;
}

/*
题目:学习使用external的用法。
*/
#include "stdio.h"
#include "conio.h"
int a,b,c;//a,b,c为全局变量,默认初始化为0
void add()
{
	int a;//在add方法中又定义了一个a,这时在该方法中全局变量a不再起作用
	a=3;
	c=a+b;//所以c的值为3+4
}
int main(void)
{
	a=b=4;//将a和b的值置为4
	add();
	printf("The value of c is equal to %d\n",c);
	getch();
	return 0;
}

/*
题目:学习使用register定义变量的方法
*/
#include <stdio.h>
#include <conio.h>
int main(void)
{
	register int i;//寄存器变量的定义把i放到寄存器中,因为该变量被cpu频繁的访问,放到寄存器中可以加快访问的速度
	int tmp=0;
	for(i=1;i<=100;i++)
	{
		tmp+=i;
	}
	printf("The sum is %d\n",tmp);
	getch();
	return 0;
}

/*
题目:宏#define命令练习(1) 
*/
#include "stdio.h"
#include "conio.h"
#define TRUE 1
#define FALSE 0
#define SQ(x) (x)*(x)//有参宏
int main()
{
	int num;
	int again=1;
	printf("\40: Program will stop if input value less than 50.\n");
	while(again)
	{
		printf("\40:Please input number==>");
		scanf("%d",&num);
		printf("\40:The square for this number is %d \n",SQ(num));
		if(num>=50)
		again=TRUE;
		else
		again=FALSE;
	}
	getch();
	return 0;
}
/*
题目:宏#define命令练习(2)
*/
#include "stdio.h"
#include "conio.h"
/*
宏定义中允许包含两道衣裳命令的情形,此时必须在最右边加上"\"。
(这是作者的笔误,正确的应该是宏定义中允许包含俩行以上的命令,也就是说两行以上命令组成的一个宏定义需要用\来进行连接)
*/
#define exchange(a,b) { \
	int t;\
	t=a;\
	a=b;\
	b=t;\
}
int main(void)
{
	int x=10;
	int y=20;
	printf("x=%d; y=%d\n",x,y);
	exchange(x,y);
	printf("x=%d; y=%d\n",x,y);
	getch();
	return 0;
}

/*
题目:宏#define命令练习(3)   
*/
#include "stdio.h"
#include "conio.h"
#define LAG >
#define SMA <
#define EQ ==
int main(void)
{
	int i=10;
	int j=20;
	if(i LAG j)
		printf("\40: %d larger than %d \n",i,j);
	else if(i EQ j)
		printf("\40: %d equal to %d \n",i,j);
	else if(i SMA j)
		printf("\40:%d smaller than %d \n",i,j);
	else
		printf("\40: No such value.\n");
	getch();
	return 0;
}

/*
题目:#if #ifdef和#ifndef的综合应用。
*/
#include "stdio.h"
#include "conio.h"
#define MAX
#define MAXIMUM(x,y) (x>y)?x:y
#define MINIMUM(x,y) (x>y)?y:x
int main()
{
	int a=10,b=20;
	//条件编译,在满足某种条件时才编译
	#ifdef MAX
		printf("\40: The larger one is %d\n",MAXIMUM(a,b));//若定义了MAX执行该语句
	#else
		printf("\40: The lower one is %d\n",MINIMUM(a,b));//没有定义MAX则执行此语句
	#endif//结束条件编译

	#ifndef MIN
		printf("\40: The lower one is %d\n",MINIMUM(a,b));
	#else
		printf("\40: The larger one is %d\n",MAXIMUM(a,b));
	#endif

	#undef MAX//此语句一下MAX的定义已经无效

	#ifdef MAX
		printf("\40: The larger one is %d\n",MAXIMUM(a,b));
	#else
		printf("\40: The lower one is %d\n",MINIMUM(a,b));
	#endif

	#define MIN

	#ifndef MIN
		printf("\40: The lower one is %d\n",MINIMUM(a,b));
	#else
		printf("\40: The larger one is %d\n",MAXIMUM(a,b));
	#endif
	getch();
	return 0;
}

/*
题目:#include 的应用练习   
*/

/*
test.h 文件如下:
#define LAG >
#define SMA <
#define EQ ==
*/
#include "test.h" /*一个新文件50.c,包含test.h*/
#include "stdio.h"
#include "conio.h"
int main(void)
{
	int i=10;
	int j=20;
	if(i LAG j)
		printf("\40: %d larger than %d \n",i,j);
	else if(i EQ j)
		printf("\40: %d equal to %d \n",i,j);
	else if(i SMA j)
		printf("\40:%d smaller than %d \n",i,j);
	else
		printf("\40: No such value.\n");
	getch();
	return 0;
}

/*
题目:学习使用按位与 & 
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int a,b;
	a=077;//111 111
	b=a&3;//000 011
	printf("\40: The a & b(decimal) is %d \n",b);
	b&=7;//000 011 & 000 111
	printf("\40: The a & b(decimal) is %d \n",b);
	getch();
	return 0;
}
/*
题目:学习使用按位或 | 
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int a,b;
	a=077;//111 111
	b=a|3;//000 011
	printf("\40: The a & b(decimal) is %d \n",b);
	b|=7;//111 111 | 000 111
	printf("\40: The a & b(decimal) is %d \n",b);
	getch();
	return 0;
}

/*
题目:学习使用按位异或 ^ 
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int a,b;
	a=077;//111 111
	b=a^3;//000 011
	printf("\40: The a ^ b(decimal) is %d \n",b);
	b^=7;//111 100 ^ 000 111 = 111 011
	printf("\40: The a ^ b(decimal) is %d \n",b);
	getch();
	return 0;
}

/*
题目:取一个整数a从右端开始的4~7位。
应该与 0111 1000=(8+16+32+64=120)10 进行与运算,这样的话1还是1,0还是0
*/
#include <stdio.h>
#include <conio.h>
int main(void)
{
	int a,b;
	printf("请输入一个整数:\n");
	scanf("%d",&a);
	b=a&120;
	printf("该整数的4-7位是:%d%d%d%d\n",b>>6&1,b>>5&1,b>>4&1,b>>3&1);
	getch();
	return 0;
}

/*
题目:学习使用按位取反~
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int a,b;
	a=15;//0000 1111
	b=~a;//11111111 11111111 11111111 11110000 该形式为机器的补码形式(内存中的存放形式),所以转换成原码为:10000000 00000000 00000000 00010000=-16
	printf("\40: The a's 1 complement(decimal) is %d \n",b);
	a=~a;//11111111 11111111 11111111 11110000 =0xfffffff0
	printf("\40: The a's 1 complement(hexidecimal) is %#x \n",a);
	getch();
	return 0;
} 

以下五例是关于画图的程序,用到的c函数库是graphics.h。因为vc上不能使用该函数库,所以自己没有动手实现,把代码贴上来,保持文章的完整性。
/*
题目:画图,学用circle画圆形。
*/
#include <graphics.h>
#include <stdio.h>
#include <conio.h>
int main()
{
	int driver,mode,i;
	float j=1,k=1;
	driver=VGA;mode=VGAHI;
	initgraph(&driver,&mode,"");
	setbkcolor(YELLOW);
	for(i=0;i<=25;i++)
	{
		setcolor(8);
		circle(310,250,k);
		k=k+j;
		j=j+0.3;
	}
	getch();
	return 0;
}
 
/*
题目:画图,学用line画直线。
*/
#include <graphics.h>
#include <stdio.h>
#include <conio.h>
int main()
{
	int driver,mode,i;
	float x0,y0,y1,x1;
	float j=12,k;
	driver=VGA;mode=VGAHI;
	initgraph(&driver,&mode,"");
	setbkcolor(GREEN);
	x0=263;y0=263;y1=275;x1=275;
	for(i=0;i<=18;i++)
	{
		setcolor(5);
		line(x0,y0,x0,y1);
		x0=x0-5;
		y0=y0-5;
		x1=x1+5;
		y1=y1+5;
		j=j+10;
	}
	x0=263;y1=275;y0=263;
	for(i=0;i<=20;i++)
	{
		setcolor(5);
		line(x0,y0,x0,y1);
		x0=x0+5;
		y0=y0+5;
		y1=y1-5;
	}
	getch();
	return 0;
}
 
/*
题目:画图,学用rectangle画方形。
*/
#include <graphics.h>
#include <stdio.h>
#include <conio.h>
int main()
{
	int x0,y0,y1,x1,driver,mode,i;
	driver=VGA;mode=VGAHI;
	initgraph(&driver,&mode,"");
	setbkcolor(YELLOW);
	x0=263;y0=263;y1=275;x1=275;
	for(i=0;i<=18;i++)
	{
		setcolor(1);
		rectangle(x0,y0,x1,y1);
		x0=x0-5;
		y0=y0-5;
		x1=x1+5;
		y1=y1+5;
	}
	settextstyle(DEFAULT_FONT,HORIZ_DIR,2);
	outtextxy(150,40,"How beautiful it is!");
	line(130,60,480,60);
	setcolor(2);
	circle(269,269,137);
	getch();
	return 0;
}
 
/*
题目:画图,综合例子。
*/
#include <graphics.h>
#include <stdio.h>
#include <conio.h>
#define PAI 3.1415926
#define B 0.809
int main()
{
	int i,j,k,x0,y0,x,y,driver,mode;
	float a;
	driver=CGA;
	mode=CGAC0;
	initgraph(&driver,&mode,"");
	setcolor(3);
	setbkcolor(GREEN);
	x0=150;y0=100;
	circle(x0,y0,10);
	circle(x0,y0,20);
	circle(x0,y0,50);
	for(i=0;i<16;i++)
	{
		a=(2*PAI/16)*i;
		x=ceil(x0+48*cos(a));
		y=ceil(y0+48*sin(a)*B);
		setcolor(2); 
		line(x0,y0,x,y);
	}
	setcolor(3);
	circle(x0,y0,60);
	/* Make 0 time normal size letters */
	settextstyle(DEFAULT_FONT,HORIZ_DIR,0);
	outtextxy(10,170,"press a key");
	getch();
	setfillstyle(HATCH_FILL,YELLOW);
	floodfill(202,100,WHITE);
	getch();
	for(k=0;k<=500;k++)
	{
		setcolor(3);
		for(i=0;i<=16;i++)
		{
			a=(2*PAI/16)*i+(2*PAI/180)*k;
			x=ceil(x0+48*cos(a));
			y=ceil(y0+48+sin(a)*B);
			setcolor(2); 
			line(x0,y0,x,y);
		}
		for(j=1;j<=50;j++)
		{
			a=(2*PAI/16)*i+(2*PAI/180)*k-1;
			x=ceil(x0+48*cos(a));
			y=ceil(y0+48*sin(a)*B);
			line(x0,y0,x,y);
		}
	}
	restorecrtmode();
	getch();
	return 0;
}
/*
题目:画图,综合例子。
*/
#include <graphics.h>
#include <stdio.h>
#include <conio.h>
#define LEFT 0
#define TOP 0
#define RIGHT 639
#define BOTTOM 479
#define LINES 400
#define MAXCOLOR 15
int main()
{
	int driver,mode,error;
	int x1,y1;
	int x2,y2;
	int dx1,dy1,dx2,dy2,i=1;
	int count=0;
	int color=0;
	driver=VGA;
	mode=VGAHI;
	initgraph(&driver,&mode,"");
	x1=x2=y1=y2=10;
	dx1=dy1=2;
	dx2=dy2=3;
	while(!kbhit())
	{
		line(x1,y1,x2,y2);
		x1+=dx1;
		y1+=dy1;
		x2+=dx2;
		y2+dy2;
		if(x1<=LEFT||x1>=RIGHT)
		 dx1=-dx1;
		if(y1<=TOP||y1>=BOTTOM)
		  dy1=-dy1;
		if(x2<=LEFT||x2>=RIGHT)
		  dx2=-dx2;
		if(y2<=TOP||y2>=BOTTOM)
		  dy2=-dy2;
		if(++count>LINES)
	 	{
		  setcolor(color);
		  color=(color>=MAXCOLOR)?0:
			++color;
	 	}
	}
	closegraph();
	getch();
	return 0;
}



原题062-065为画图的程序,vc中不能实现,本人就没实现,先将062-065改为自己的程序题目
/*
题目:打印出杨辉三角形(要求打印出10行如下图)   
如图:
       1
      1  1
      1  2  1
      1  3  3  1
      1  4  6  4  1
      1  5  10 10 5  1 
介绍:
杨辉三角形,又称贾宪三角形,帕斯卡三角形,是二项式系数在三角形中的一种几何排列。
性质:
前提:端点的数为1.
1、每个数等于它上方两数之和,即第n+1行的第i个数等于第n行的第i-1个数和第i个数之和
2、每行数字左右对称,由1开始逐渐变大。 
3、第n行的数字有n项。
*/
//1、直角三角形杨辉三角
/*
#include <stdio.h>
#include <conio.h>
int main(void)
{
	int a[10][10];
	int i,j;//用i控制行数,用j控制列数
	for(i=0;i<10;i++)
	{
		for(j=0;j<i+1;j++)
		{
			if(i==j || j==0)
			{
				a[i][j]=1;
			}
			else
			{
				a[i][j]=a[i-1][j-1]+a[i-1][j];
			}
			//打印直角形杨辉三角
			printf("%5d",a[i][j]);
		}
		printf("\n");
	}
	getch();
	return 0;
}
*/
/*
//2、使用数组打印金字塔型杨辉三角(杨辉三角中除了最外层(不包括杨辉三角底边)的数为1外,其余的数都是它肩上两个数之和。用数组输出杨辉三角就用这个性质。)
#include <stdio.h>
#include <conio.h>
int main(void)
{
	int a[10][10];
	int i,j;//用i控制行数,用j控制列数
	for(i=0;i<10;i++)
	{
		for(j=10;j>=i;j--)
		{
			printf("%2c",' ');//两个空格
		}
		for(j=0;j<i+1;j++)
		{
			if(i==j || j==0)
			{
				a[i][j]=1;
			}
			else
			{
				a[i][j]=a[i-1][j-1]+a[i-1][j];
			}
			//打印金字塔形杨辉三角
			printf("%3d ",a[i][j]); //%3d后一个空格
		}
		printf("\n");
	}
	getch();
	return 0;
}
*/
//3、不用数组输出金字塔形杨辉三角(杨辉三角的第n行恰好是C(n-1,0)~C(n-1,n)。这里的C表示组合。不用数组输出杨辉三角就用这个性质。)
#include <stdio.h>
#include <conio.h>
int main(void)
{
	int n=1,k=1;
	int i,j;//用i控制行数,用j控制列数
	int a,b;
	for(i=0;i<10;i++)
	{
		for(j=10;j>=i;j--)
		{
			printf("%2c",' ');//两个空格
		}
		for(j=0;j<i+1;j++)
		{
			if(j==0 || i==j)
			{
				printf("%3d",1);
			}
			else
			{
				a=i;
				for(b=0;b<j;b++)
				{
					n*=a;
					a--;
				}
				a=j;
				for(b=a;b>1;b--)
				{
					k*=a;
					a--;
				}
				//打印金字塔形杨辉三角
				printf("%3d ",n/k); //%3d后一个空格
				n=1;
				k=1;
			}
		}
		printf("\n");
	}
	getch();
	return 0;
}

 
/*
题目:读入正在编写的.c文件,在屏幕上输出。
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	FILE *fp;
	char a;
	if((fp=fopen("101.c","rb"))==NULL)
	{
		printf("文件读取失");
		getch();
		exit(1);
	}
	a=fgetc(fp);
	while(a!=EOF)
	{
		putchar(a);
		a=fgetc(fp);
	}
	fclose(fp);
	getch();
	return 0;
}

 
/*
从键盘输入一行字符,写入一个文件, 再把该文件内容读出显示在屏幕上
*/
#include <stdio.h>
#include <string.h>
#include <conio.h>
#include <stdlib.h>
int main()
{
	FILE *fp;
	char str[30];
	char a;
	int i;
	if((fp=fopen("102.txt","wb+"))==NULL)
	{
		printf("文件打开失败!\n");
		getch();
		exit(1);
	}
	printf("请输入一行字符:\n");
	gets(str);
	for(i=0;i<strlen(str);i++)
	{
		fputc(str[i],fp);
	}
	rewind(fp);
	while((a=fgetc(fp))!=EOF)
	{
		putchar(a);
	}
	fclose(fp);
	getch();
	return 0;
}

 
/*
题目:从103.txt文件中读入一个含10个字符的字符串。使用fgets()函数
*/
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
int main()
{
	FILE *fp;
	char str[11];
	if((fp=fopen("103.txt","rb"))==NULL)
	{
		printf("文件读取失败!\n");
		getch();
		exit(1);
	}
	fgets(str,11,fp);
	puts(str);
	getch();
	return 0;
}

 
/*
题目:从键盘输入两个学生数据,写入一个文件中, 再读出这两个学生的数据显示在屏幕上。
*/
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>
typedef struct stu
{
	int num;
	char str[10];
}student;
int main()
{
	student st[2];
	student s[2];
	int i;
	FILE *fp;
	printf("请输入俩个学生的数据:\n");
	for(i=0;i<2;i++)
	{
		scanf("%d %s",&st[i].num,st[i].str);
	}
	if((fp=fopen("104.txt","wt+"))==NULL)
	{
		printf("文件打开失败!\n");
		getch();
		exit(1);
	}
	fwrite(st,sizeof(student),2,fp);
	rewind(fp);
	fread(s,sizeof(student),2,fp);
	for(i=0;i<2;i++)
	{
		printf("%d %s",s[i].num,s[i].str);
	}
	fclose(fp);
	getch();
	return 0;
}

 

/*
题目:输入3个数a,b,c,按大小顺序输出。 
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int i,j,k;//i=i>j?(i>k?i:k):(j>k?j:k);求三个数中最大的数用此条语句
	int a[3],n; 
	printf("请输入三个数:\n");
	scanf("%d%d%d",&i,&j,&k);
	// 三目运算符和逗号表达式  
	a[0]=i;
	a[1]=n=(i>j?(a[0]=j,i):j); //此时a[0]中存放一个较小的数,a[1]中存放一个较大的数
	a[2]=a[1]>k?( k>a[0]?(a[1]=k):(a[1]=a[0],a[0]=k),n):k;
	for(i=2;i>=0;--i)
	{
		printf("%d\t",a[i]);
	}
	getch();
	return 0;	
}
/*
题目:输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。 
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int i,j;
	int a[10];
	int tem;
	int n=0,m=0;//n记录最小值得位置,m记录最大值的位置
	printf("请输入10个整数作为数组中的元素:\n");
	for(i=0;i<10;i++)
	{
		scanf("%d",&a[i]);
	}
	for(i=0;i<10;i++)
	{
		if(a[i]>a[m])
		{
			m=i;
		}
		if(a[i]<a[n])
		{
			n=i;
		}
	}
	//如果最小的元素和最大的元素位于第一个位置和第十个位置,执行此情况
	if(n==0 && m==9)
	{
		tem=a[0];
		a[0]=a[9];
		a[9]=tem;
	}
	else if(n==0)
	{
		//先将最小值与最后一个位置交换
		tem=a[n];
		a[n]=a[9];
		a[9]=tem;
		tem=a[m];
		a[m]=a[0];
		a[0]=tem;
	}
	else
	{
		//先将最大值与第一个位置交换
		tem=a[m];
		a[m]=a[0];
		a[0]=tem;
		tem=a[n];
		a[n]=a[9];
		a[9]=tem;
	}
	for(i=0;i<10;i++)
	{
		printf("%d\t",a[i]);
	}
	getch();
	return 0;	
}

/*
题目:有m个整数,使其前面各数顺序向后移n个位置,最后n个数变成最前面的n个数
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int number[20],n,m,i;
	int a[20],j;
	printf("the total numbers is:");
	scanf("%d",&m);
	printf("back n:");
	scanf("%d",&n);
	printf("please enter the number:");
	for(i=0;i<m;i++)
	{
		scanf("%d,",&number[i]);
	}
	j=0;
	//将后n个元素存储到数组a中
	for(i=m-n;i<m;i++)
	{
		a[j]=number[i];
		j++;
	}
	//向后移动元素n位
	for(i=m-n-1;i>=0;i--)
	{
		number[i+n]=number[i];
	}
	//将存储的元素放到前边的n个位置
	for(i=0;i<n;i++)
	{
		number[i]=a[i];
	}
	for(i=0;i<m;i++)
	{
		printf("%d,",number[i]);
	}
	printf("\n");
	getch();
	return 0;
}

/*
题目:有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出
   圈子,问最后留下的是原来第几号的那位。
*/
#include <stdio.h>
#include <conio.h>
int n=100;
int m=3;
int p[100];
int main(void)  
{  
    int i;  
    int count;//count当做数数的变量   
    int people=n;//定义没有出圈的人数   
    int tem;//存放出圈人的编号   
    int j;  
    //为这100个人进行编号   
    for(i=0;i<n;i++)  
    {  
        p[i]=i+1;  
    }  
    i=0;  
    count=1;//数数的下标从零开始,count从1开始。也就是说以i为下标的编号,正是count所数的编号,count和i是同时增加的。   
    //在还没有人出圈之前,people=100,每出圈一个人people-1。当只剩下一个人的时候循环停止。   
    while(people>1)  
    {  
        i=i%people;//已经出圈人的下标不再计算之内,也就是说数到数组中最后一个没有出圈的编号的时候,i重新指向0   
        count=count%m;//count数到3的时候再从零开始数   
        //count数到3的时候count的值为0,执行下面的if语句   
        if(count==0)  
        {  
            //下面的循环将出圈的人之后的编号往前移动一位,出圈的人的编号放在p数组中的最后一位,视为出圈,同时人数减少一个   
            tem=p[i];  
            for(j=i;j<people-1;j++)  
            {  
                p[j]=p[j+1];  
            }  
            p[j]=tem;  
            people--;  
            count++;//根据题意,count重新开始数数的位置是当前位置   
        }  
        i++;  
        count++;  
    }
	printf("最后留下来的是%d号\n",p[0]);
	getch();
	return 0;
}  

/*
题目:写一个函数,求一个字符串的长度,在main函数中输入字符串,并输出其长度。
*/
#include <stdio.h>
#include <conio.h>
int strlength(char *str)
{
	char *p=str;
	int count=0;
	while(*p!='\0')
	{
		p++;
		count++;
	}
	return count;
}
int main()
{
	char str[50];
	printf("输入一个字符串:\n");
	scanf("%s",str);
	printf("该字符串的长度为%d:\n",strlength(str));
	getch();
	return 0;
}

原题072-075是有关链表操作的,本人自己写了有关链表的代码,见博客数据结构单链表
/*
题目:编写input()和output()函数输入,输出5个学生的数据记录。
*/
#include <stdio.h>
#include <conio.h>
typedef struct student
{
	int num;
	char name[20];
	int score;
}stu;
void input(stu *s);
void output(stu *s);
int main()
{
	stu s[5];
	input(s);
	output(s);
	return 0;
}
void input(stu *s)
{
	int i;
	printf("输入学生的信息:\n");
	for(i=0;i<5;i++)
	{
		scanf("%d %s %d",&s[i].num,s[i].name,&s[i].score);
	}
}
void output(stu *s)
{
	int i;
	for(i=0;i<5;i++)
	{
		printf("%d%s%d\n",s[i].num,s[i].name,s[i].score);
	}
}


/*
题目:编写一个函数,输入n为偶数时,调用函数求1/2+1/4+...+1/n,当输入n为奇数时,调用函数
1/1+1/3+...+1/n
*/
#include <stdio.h>
#include <conio.h>
float even(int n)
{
	int i;
	float sum=0.0;
	for(i=2;i<n+1;i+=2)
	{
		sum+=1.0/i;
	}
	return sum;
}
float odd(int n)
{
	int i;
	float sum=0.0;
	for(i=1;i<n+1;i+=2)
	{
		sum+=1.0/i;
	}
	return sum;
}
int main()
{
	int n;
	float sum;
	printf("输入一个整数:\n");
	scanf("%d",&n);
	if(n%2==0)
	{
		sum=even(n);
	}
	else
	{
		sum=odd(n);
	}
	printf("sum=%f\n",sum);
	getch();
	return 0;
}
/*
题目:填空练习(指向指针的指针)
*/
#include "stdio.h"
#include "conio.h"
int main()
{
	char *s[]={"man","woman","girl","boy","sister"};
	char **q;
	int k;
	for(k=0;k<5;k++)
	{ 
		q=s+k;/*这里填写什么语句*/
		printf("%s\n",*q);
	}
	getch();
	return 0;
}

/*
题目:找到年龄最大的人,并输出。请找出程序中有什么问题。
*/
#define N 4
#include <stdio.h>
#include <conio.h>
static struct man
{
	char name[20];
	int age;
}person[N]={"li",18,"wang",19,"zhang",20,"sun",22};
main()
{
	struct man *q,*p;
	int i,m=0;
	p=person;
	for (i=0;i<N;i++)
	{
		if(m<p->age)
			q=p;//原来的写法q=p++;
		p++;
		m=q->age;
	}
	printf("%s,%d",(*q).name,(*q).age);
	getch();
	return 0;
}

/*
题目:字符串排序。
*/
#include "stdio.h"
#include "conio.h"
char swap(char *p1,char *p2);
int main()
{
	char *str1[20],*str2[20],*str3[20];
	printf("please input three strings\n");
	scanf("%s",str1);
	scanf("%s",str2);
	scanf("%s",str3);
	if(strcmp(str1,str2)>0) 
		swap(str1,str2);
	if(strcmp(str1,str3)>0) 
		swap(str1,str3);
	if(strcmp(str2,str3)>0) 
		swap(str2,str3);
	printf("after being sorted\n");
	printf("%s\n%s\n%s\n",str1,str2,str3);
	getch();
	return 0;
}
char swap(char *p1,char *p2)
{
	char *p[20];
	strcpy(p,p1);
	strcpy(p1,p2);
	strcpy(p2,p);
}

/*
题目:海滩上有一堆桃子,五只猴子来分。第一只猴子把这堆桃子平均分为五份,多了一个,这只
猴子把多的一个扔入海中,拿走了一份。第二只猴子把剩下的桃子又平均分成五份,又多了
一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只猴子都是这样做的,
问海滩上原来最少有多少个桃子?
*/
//假设最后一个猴子拿走了一份后,剩下4个桃子,这时,原来海滩上的桃子数最少,若在计算过程中出现了不能整除的情况,则假设剩下8个,依次以4的倍数递增
#include <stdio.h>
#include <conio.h>
int main()
{
	int i,n;
	int j=1;
	while(1)
	{
		n=4*j;
		for(i=5;i>0;i--)
		{
			if(n%4==0)
			{
				n=n/4*5+1;
			}
			else
				break;
		}
		if(i==0)
			break;
		j++;
	}
	printf("海滩上原来最少有%d个桃子\n",n);
	return 0;
}

/*
题目:809*??=800*??+9*??+1 其中??代表的两位数,8*??的结果为两位数,9*??的结果为3位数。求??代表的两位数,及809*??后的结果。
此题有误
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int n;
	for(n=10;n<100;n++)
	{
		if(8*n<100 && 9*n>99 && 9*n<1000)
		{
			printf("%d\n",n);
			if(809*n==800*n+9*n+1)
			{
				printf("??代表的俩位数是:%d,809*??的结果为:%d\n",n,809*n);
			}
		}
	}
	return 0;
}


/*
题目:八进制转换为十进制
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	int n=0;
	char *p,str[10];
	p=str;
	printf("输入一个八进制数:\n");
	scanf("%s",str);
	while(*p != '\0')
	{
		n=(*p-'0')+8*n;//八进制数左移一位对应的十进制数扩大8倍
		p++;
	}
	printf("对应的十进制数是:%d\n",n);
	return 0;
}

/*
题目:求0—7所能组成的奇数个数。
*/
#include "stdio.h"
#include "conio.h"
int main()
{
	long sum=4,s=4;//当一位数的时候,奇数的个数是4
	int j;
	for(j=2;j<=8;j++)/*j is place of number*/
	{
		printf("\n%ld",sum);
		if(j<=2)
			s*=7;//俩位数的时候,最高位不能为0,个位只能为4个奇数
		else
			s*=8;//当三位数或者三位以上的数时,最高位有7个数字可供选择,最低位有4个数字供选择,总共有28种方案,中间的位数的数字有8种选择
		sum+=s;
	}
	printf("\nsum=%ld",sum);
	getch();
	return 0;
}

/*
题目:一个偶数总能表示为两个素数之和。
这句话说的不对,应该除二以外
*/
#include <stdio.h>
#include <conio.h>
#include <math.h>
int sushu(int n)
{
	int i;
	for(i=2;i<(int)sqrt(n)+1;i++)
	{
		if(n%i==0)
			return 0;
	}
	return 1;
}
int main()
{
	int n;
	int i;
	printf("输入一个偶数:\n");
	scanf("%d",&n);
	for(i=2;i<n;i++)
	{
		if(sushu(i) && sushu(n-i) && (n-i)>1)
		{
			printf("%d=%d+%d\n",n,i,n-i);
		}
	}
	getch();
	return 0;
}

/*
题目:判断一个素数能被几个9整除
*/
#include <stdio.h>
#include <conio.h>
#include <math.h>
#include <stdlib.h>
int sushu(int n)
{
	int i;
	for(i=2;i<(int)sqrt(n)+1;i++)
	{
		if(n%i==0)
			return 0;
	}
	return 1;
}
int main()
{
	int n;
	int i=1,j=9;
	printf("输入一个素数:\n");
	scanf("%d",&n);
	if(!sushu(n))
	{
		printf("该数不是素数!\n");
		exit(1);
	}
	while(j<=n)
	{
		if(n%j==0)
		{
			printf("%d能被%d个九整除\n",n,i);
		}
		j=pow(10,i)*9+j;
		i++;
	}
	if(j>n)
		printf("没有找到满足条件的九的个数!\n");
	getch();
	return 0;
}

/*
题目:两个字符串连接程序
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	char str1[20],str2[10];
	char *p1=str1,*p2=str2;
	printf("输入俩个字符串:\n");
	scanf("%s%s",str1,str2);
	while(*p1 != '\0')
	{
		p1++;
	}
	while(*p2 != '\0')
	{
		*p1=*p2;
		p1++;
		p2++;
	}
	*p1='\0';
	printf("%s\n",str1);
	getch();
	return 0;
}

/*
题目:回答结果(结构体变量传递)
*/
#include "stdio.h"
#include "conio.h"
struct student
{
	int x;
	char c;
}a;
void f(struct student);
int main()
{
	a.x=3;
	a.c='a';
	f(a);
	printf("%d,%c",a.x,a.c);
	getch();
	return 0;
}
void f(struct student b)
{
	b.x=20;
	b.c='y';
}

/*
题目:读取7个数(1—50)的整数值,每读取一个值,程序打印出该值个数的*。
*/
#include "stdio.h"
#include "conio.h"
int main()
{
	int n,i,j;
	printf("输入7个数:\n");
	for(j=0;j<7;j++)
	{
		scanf("%d",&n);
		for(i=1;i<n+1;i++)
		{
			printf("*");
		}
		printf("\n");
	}
	getch();
	return 0;
}

/*
题目:某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:
每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。
*/
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
int main()
{
	int i,n;
	int gw,sw,bw,qw;
	printf("请输入四位整数:\n");
	scanf("%d",&n);
	if(n<1000 || n>9999)
	{
		printf("输入有误!\n");
		exit(1);
	}
	gw=n%10;
	sw=n%100/10;
	bw=n/100%10;
	qw=n/1000;
	gw=(gw+5)%10;
	sw=(sw+5)%10;
	bw=(bw+5)%10;
	qw=(qw+5)%10;
	i=gw*1000+sw*100+bw*10+qw;
	printf("加密后的数字为:%d\n",i);
	getch();
	return 0;
}


/*
题目:专升本一题,读结果。
*/
#include <stdio.h>
#define M 5
int main()
{
	int a[M]={1,2,3,4,5};
	int i,j,t;
	i=0;j=M-1;//i=0 j=4
	while(i<j)
	{
		t=*(a+i);
		*(a+i)=*(a+j);
		*(a+j)=t;
		i++;
		j--;
	}
	for(i=0;i<M;i++)
		printf("%d",*(a+i));
	getch();
	return 0;
}

/*
题目:时间函数举例1
*/
#include <stdio.h>
#include <conio.h>
#include <time.h>
int main()
{
	time_t lt; /*define a longint time varible*/
	lt=time(NULL);/*system time and date*/
	printf(ctime(<)); /*english format output*/
	printf(asctime(localtime(<)));/*tranfer to tm*/
	printf(asctime(gmtime(<))); /*tranfer to Greenwich time*/
	getch();
	return 0;
}

/*
题目:时间函数举例2
*/
/*calculate time*/
#include "time.h"
#include "stdio.h"
#include "conio.h"
int main()
{
	time_t start,end;
	int i;
	start=time(NULL);
	for(i=0;i<300;i++)
		printf("\1\1\1\1\1\1\1\1\1\1\n");
	end=time(NULL);
	printf("\1: The different is %6.3f\n",difftime(end,start));
	getch();
	return 0;
}

/*
题目:时间函数举例3
*/
/*calculate time*/
#include "time.h"
#include "stdio.h"
#include "conio.h"
int main()
{
	clock_t start,end;
	int i;
	double var;
	start=clock();
	for(i=0;i<10000;i++)
		printf("\1\1\1\1\1\1\1\1\1\1\n");
	end=clock();
	printf("\1: The different is %6.3f\n",(double)(end-start));
	getch();
	return 0;
}

/*
用fscanf和fprintf函数完成从键盘输入两个学生数据,写入一个文件中,再读出这两个学生的数据显示在屏幕上。
*/
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>
typedef struct stu
{
	int num;
	char str[10];
}student;
int main()
{
	student st[2];
	student s[2];
	int i;
	FILE *fp;
	printf("请输入俩个学生的数据:\n");
	for(i=0;i<2;i++)
	{
		scanf("%d %s",&st[i].num,st[i].str);
	}
	if((fp=fopen("105.txt","wt+"))==NULL)
	{
		printf("文件打开失败!\n");
		getch();
		exit(1);
	}
	for(i=0;i<2;i++)
	{
		fprintf(fp,"%d %s\n",st[i].num,st[i].str);
	}
	rewind(fp);
	for(i=0;i<2;i++)
	{
		fscanf(fp,"%d%s",&s[i].num,&s[i].str);
		printf("%d %s",s[i].num,s[i].str);
	}
	fclose(fp);
	getch();
	return 0;
}

/*
题目:在学生文件106.txt中读出第二个学生的数据。
*/
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>
typedef struct stu
{
	int num;
	char str[10];
}student;
int main()
{
	student st;
	student *s=&st;
	FILE *fp;
	if((fp=fopen("106.txt","rb+"))==NULL)
	{
		printf("文件打开失败!\n");
		getch();
		exit(1);
	}
	fseek(fp,(long)sizeof(student),0);
	fread(s,sizeof(student),1,fp);
	printf("%d %s",s->num,s->str);
	fclose(fp);
	getch();
	return 0;
}

/*
题目:计算字符串中子串出现的次数
*/
#include <stdio.h>
#include <conio.h>
int main()
{
	char str[20],substr[20];
	char *p,*q,*tem1=NULL,*tem2=NULL;  
    int slen,sublen;  
    int count=0;  
	printf("请输入一个字符串及其子串:\n");
	scanf("%s%s",str,substr);
	p=str;
	q=substr;
	slen=strlen(str);
	sublen=strlen(substr);
    while(p-str<slen)  
    {  
        tem1=p;  
        tem2=q;  
        while(*tem1==*tem2 && tem2-substr<sublen)  
        {  
            tem1++;  
            tem2++;  
            if(tem2-substr==sublen)  
            {  
                count++;  
            }  
        }  
        p++;  
    }  
	printf("字符串中子串出现的次数为:%d\n",count);
	getch();
	return 0;
}

/*
题目:从键盘输入一些字符,逐个把它们送到磁盘上去,直到输入一个#为止。
*/
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
int main()
{
	FILE *fp;
	int a;
	printf("输入你要存放到磁盘中的数据:\n");
	if((fp=fopen("097.txt","wb"))==NULL)
	{
		printf("文件打开失败!\n");
		exit(1);
	}
	while((a=getchar())!='#')
	{
		fputc(a,fp);
	}
	fclose(fp);
	return 0;
}

/*
题目:从键盘输入一个字符串,将小写字母全部转换成大写字母,然后输出到一个磁盘文件“test”中保存。
输入的字符串以!结束。 
*/
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
int main()
{
	FILE *fp;
	int a;
	printf("输入你要存放到磁盘中的数据:\n");
	if((fp=fopen("098.txt","wb"))==NULL)
	{
		printf("文件打开失败!\n");
		exit(1);
	}
	while((a=getchar())!='!')
	{
		if(a<='z' && a>='a')
		{
			a-=32;
		}
		fputc(a,fp);
	}
	fclose(fp);
	return 0;
}

/*
题目:有两个磁盘文件A和B,各存放一行字母,要求把这两个文件中的信息合并(按字母顺序排列), 
输出到一个新文件C中。
*/
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
int main()
{
	FILE *p1,*p2,*p3;
	char str[30],*pstr;
	int i,j,tem;
	pstr=str;
	if((p1=fopen("1.txt","rt"))==NULL)
	{
		printf("文件打开失败!\n");
		exit(1);
	}
	if((p2=fopen("2.txt","rt"))==NULL)
	{
		printf("文件打开失败!\n");
		exit(1);
	}
	if((p3=fopen("3.txt","wt"))==NULL)
	{
		printf("文件打开失败!\n");
		exit(1);
	}
	fgets(str,15,p1);
	while(*pstr != '\0')
	{
		pstr++;
	}
	fgets(pstr,15,p2);
	for(i=0;i<strlen(str)-1;i++)
	{
		for(j=i+1;j<strlen(str);j++)
		{
			if(str[j]<str[i])
			{
				tem=str[j];
				str[j]=str[i];
				str[i]=tem;
			}
		}
	}
	fputs(str,p3);
	getch();
	return 0;
}

/*
题目:有五个学生,每个学生有3门课的成绩,从键盘输入以上数据(包括学生号,姓名,三门课成绩),
计算出平均成绩,将原有的数据和计算出的平均分数存放在磁盘文件"stud"中。
*/
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
struct student
{
	char num[6];
	char name[8];
	int score[3];
	float avr;
}stu[5];
int main()
{
	int i,j,sum;
	FILE *fp;
	/*input*/
	for(i=0;i<5;i++)
	{
		printf("\n please input No. %d score:\n",i);
		printf("stuNo:");
		scanf("%s",stu[i].num);
		printf("name:");
		scanf("%s",stu[i].name);
		sum=0;
		for(j=0;j<3;j++)
		{
			printf("score %d.",j+1);
			scanf("%d",&stu[i].score[j]);
			sum+=stu[i].score[j];
		}
		stu[i].avr=(float)(sum/3.0);
	}
	if((fp=fopen("100.txt","wt"))==NULL)
	{
		printf("文件打开失败!\n");
		exit(1);
	}
	for(i=0;i<5;i++)
	{
		if(fwrite(&stu[i],sizeof(struct student),1,fp)!=1)
			printf("file write error\n");
	}
	fclose(fp);
	getch();
	return 0;
}
 


 

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值