经典的10道C语言例题(含参考代码)

1.打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如,153是一个“水仙花数”,因为153=1^3+5^3+3^3。

#include<stdio.h>
#include<math.h>
int main()
{
	int bai_wei,shi_wei,ge_wei,i,sum=0;
	for(i=100;i<1000;i++)
	{
		bai_wei=i/100;
		shi_wei=(i%100)/10;
		ge_wei=i%10;
		if(i==pow(bai_wei,3)+pow(shi_wei,3)+pow(ge_wei,3))
		{
			printf("%d ",i);
			sum++;
			if(sum%5==0)
				printf("\n");
		}
	}
	printf("\n");
	return 0;
}

2.请输入任意两个整数x和y,求其最大公约数和最小公倍数。

#include<stdio.h>
int main()
{
	int x,y,min,max,i;
	printf("请输入任意两个整数:");
	scanf("%d%d",&x,&y);
	min=x>y?y:x;
	max=x>y?x:y;
	for(i=min;i>0;i--)
		if(x%i==0&&y%i==0)
		{
			printf("这两个整数的最大公约数为:%d\n",i);
			break;
		}
	for(i=max;i<=x*y;i++)
		if(i%x==0&&i%y==0)
		{
			printf("这两个整数的最小公倍数为:%d\n",i);
			break;
		}
	return 0;
}

3、输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

#include<stdio.h>
#include<string.h>
#define N 50
int main()
{
	int sum1=0,sum2=0,sum3=0,sum4,i=0;
	char str[N];
	printf("请输入一串字符串:");
	scanf("%s",str);
	for(i=0;i<strlen(str);i++)
	{
		if((str[i]>='a'&&str[i]<='z')||(str[i]>='A'&&str[i]<='Z'))
			sum1++;
		if(str[i]==' ')
			sum2++;
		if(str[i]>='0'&&str[i]<='9')
			sum3++;
	}
	sum4=strlen(str)-sum1-sum2-sum3;
	printf("英文字母的个数:%d\n",sum1);
	printf("空格的个数:%d\n",sum2);
	printf("数字的个数:%d\n",sum3);
	printf("其他符号的个数:%d\n",sum4);
	return 0;
}

4、求s=a+aa+aaa+aaaa+aa…a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。

#include<stdio.h>
#include<math.h>
int main()
{
	int a,n,s=0,i,x=0,y=0;
	printf("请输入整数a的值:");
	scanf("%d",&a);
	printf("请输入相加的个数n:");
	scanf("%d",&n);
	for(i=0;i<n;i++)
	{
		x=y+2*pow(10,i);
		y=x;
		s=s+x;
	}
	printf("s=%d\n",s);
	return 0;
}

5.一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3。编程找出1000以内的所有完数。

#include<stdio.h>
int main()
{
	int sum=0,i,j;
	printf("在1000以内的完数有:");
	for(i=2;i<=1000;i++)
	{
		for(j=1;j<i;j++)
			if(i%j==0)
				sum=sum+j;
		if(sum==i)
			printf("%d ",i);
		sum=0;
	}
	printf("\n");
	return 0;
}

6.输入一个不多于5位的正整数,要求:1、求它是几位数;2、逆序打印出个位数字。

#include<stdio.h>
int pows(int a,int n)
{
	int sum=1,i;
	for(i=0;i<n;i++)
		sum=sum*a;
	return sum;
}
int main()
{
	int n,i,k,x;
	printf("n=");
	scanf("%d",&n);
	for(i=1;i<6;i++)
		if(n/pows(10,i)==0)
		{
			printf("%d\n",i);
			k=i;
			break;
		}
	for(i=0;i<k;i++)
	{
		x=n/pows(10,i)%10;
		printf("%d",x);
	}
	printf("\n");
	return 0;
}

7.输入一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。

#include<stdio.h>
int main()
{
	int n,a[5],i=0;
	printf("请输入一个5位数:");
	scanf("%d",&n);
	while(n!=0)
	{
		a[i]=n%10;
		n=n/10;
		i++;
	}
	if(a[0]==a[4]&&a[1]==a[3])
		printf("这个数是回文数\n");
	else
		printf("这个数不是回文数\n");
	return 0;
}

8.利用递归算法,将所输入的5个字符,以相反顺序打印出来。

#include<stdio.h>
void digui(char a[],int n)
{
	if(n==1)
		printf("%c",a[0]);
	else
	{
		printf("%c",a[n-1]);
		digui(a,n-1);
	}
}
int main()
{
	char str[5];
	printf("请输入5个字符:");
	scanf("%s",str);
	digui(str,5);
	printf("\n");
	return 0;
}

9.有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…球出这个序列的前20项之和。

#include<stdio.h>
int main()
{
	int i,a=1,b=1;
	float sum=0.0;
	for(i=1;i<=20;i++)
	{
		sum=sum+(float)(a+i)/b;
		b=a+i;
		a=i;
	}
	printf("sum=%f\n",sum);
	return 0;
}

10.利用递归算法求5!。

#include<stdio.h>
int digui(int n)
{
	if(n==1)
		return 1;
	else 
		return n*digui(n-1);
}
int main()
{
	int n,sum;
	printf("n:");
	scanf("%d",&n);
	sum=digui(n);
	printf("sum=%d\n",sum);
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值