(一)打印菱形
//在屏幕上输出一个用*打印出来的菱形图案
- 图像关于中间一行对称,定义中间最长一行的一行为行数line,则根据中间一行可分为上、下两部分;
- 分析图形得到上部分:总共line行:
第一行:line-1个空格,1个 星号;第二行:line-2个空格,3个星号;…
第 i 行:line-i个空格, 2*i-1个星号; - 分析图形下部分:总共 line-1行:
第一行:1个空格, 2 * (line-1) -1个星号;第二行:2个空格, 2 * ((line-1) -1)-1个星号;…
第 i 行:i个空格, 2 * ((line-1) -(i-1))-1 个星号;
代码如下:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
int main()
{
int line = 0;
printf("请输入行数;");
scanf("%d",&line);//上半部分行数
//上半部分
int i = 0;
int j = 0;
for (i = 1; i <=line; i++)
{
//空格
for (j = 1; j<=line - i; j++)
{
printf(" ");
}
for (j = 1; j <= 2 * i - 1; j++)
{
//星号
printf("*");
}
printf("\n");
}
//打印下部分
for (i = 1; i <= line-1; i++)
{
//空格
for (j = 1; j <=i; j++)
{
printf(" ");
}
for (j = 1; j <= 2 * ((line-1) -(i-1))-1; j++)
{
printf("*");
}
printf("\n");
}
system("pause");
return 0;
}
(二)水仙花数
//求出0~999之间的所有水仙花数并输出;
“水仙花数”是指一个三位数,其各位数字的立方和正好等于该数本身 ,如:153=1+5+3?,则153 是一个“水仙花数”;
在数论中水仙花数也称为自恋数,自幂数,阿姆斯壮数或阿姆斯特朗数 ,是指一个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
解题思路 :
- 采用除十取整办法分解出该数的各个位 ,并用count表示分解完后的次数也就是count次方;
- 将各个位数的count次方和与该数相比看是否相等,相等则打印出来;
- 使用pow函数求次方,输出和sum;
- 代码如下:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>#include<math.h>
int main()
{
int i = 0;
for (i = 100; i <1000; i++)
{
int sum = 0;
int count = 0;
int tmp = i;
//求各个位上的数字
while (tmp != 0)
{
count++;
tmp /= 10;
}
tmp = i;
//各个位上的数字的count次方求和
while (tmp!=0)
{
sum += pow((double)(tmp % 10), count);
tmp = tmp / 10;
}
if (sum == i)
{
printf("%d\n",sum);
}
}
system("pause");
return 0;
}