在最近两周的时间里我对C语言的基础进行了仔细的学习,并用C语言的程序实现了一些比较有代表性的例子。使我对C语言的基础有了更加深入的了解!下面我给大家分享几个例题,希望对大家有所帮助。
1. “水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身,如;153=1+5+3 ? ,则153是一个“水仙花数”。
在数论中,水仙花数(Narcissistic number)也称为自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),是指一N位数,其各个数之N次方和等于该数。
例如153、370、371及407就是三位数的水仙花数,其各个数之立方和等于该数:
153 = 1^3 + 5^3 + 3^3。
370 = 3^3 + 7^3 + 0^3。
371 = 3^3 + 7^3 + 1^3。
407 = 4^3 + 0^3 + 7^3。
第一个例子便是编程实现水仙花数的查找:
#include<stdio.h>
int main()
{
printf("100~999之间的所有“水仙花数”:\n");
for (int i = 100; i < 1000; i++)
{
int x,a,b,c;
a = i / 100; //求出三位数字的百位
b = i / 10 % 10; //求出三位数字的十位
c = i % 10; //求出三位数字的个位
x = a*a*a + b*b*b + c*c*c;
if (i == x) //判断该数字是否为水仙花数
{
printf("%d ", x);
}
}
return 0;
}
程序运行结果:
2. 杨辉三角形,又称贾宪三角形,帕斯卡三角形,是二项式系数在三角形中的一种几何排列。杨辉三角形同时对应于二项式定理的系数。
由于杨辉三角形的特点,今天的第二个例子便是编程输出杨辉三角形:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
int i = 0, j = 0; //定义一个二维数组存杨辉三角形的每一位
int x = 0;
printf("请输入要打印的杨辉三角的行数:\n");
scanf("%d",&x);
for (i = 0; i < x; i++)
{
for (j = 0; j < x - i; j++)
{
printf(" "); //打印两个空格以便三角形对称
}
for (j = 0; j <= i; j++)
{
if (i == j || j == 0) //給三角形的两边赋值均为1
{
a[i][j] = 1;
printf("%3d ", a[i][j]);
}
else //找出每个数字的特点:该数为上一行紧挨的两数字之和
{
a[i][j] = a[i - 1][j - 1] + a[i - 1][j];
printf("%3d ", a[i][j]);
}
}
printf("\n");
}
return 0;
}
程序执行结果:
今天的两个例子对于c语言来说属于难度较低的级别,但这两个例子将数学与编程完美相结合,很好地使编程者理清思路。这是每一位程序员所必须做到的第一步!并且这两个例子算法难度适中,比较适合新手的学习,在以后的博客中我会继续分享一些c语言的程序,难度也会适当增加,希望大家喜欢!