//使用指针打印数组内容
int main()
{
int arr[5] = { 1,2,3,4,5 };
//计算元素个数
int sz = sizeof(arr) / sizeof(arr[0]);
//定义指针变量
int* p = arr;
//循环
int i = 0;
for (i = 0; i < sz; i++)
{
printf("%d ", *(p + i));
}
return 0;
}
打印菱形
//打印菱形
//我们可以将菱形分为上半部分和下半部分
//我们观察到上半部分空格是逐渐-1的
//(*)是逐渐加2的
//下半部分空格是逐渐 + 1的
//(*)是逐渐-2的
int main()
{
int i = 0;
int j = 0;
//上半部分
//外循环是上半部分的行数
for (i = 0; i < 7; i++)
{
//打印'空格'
for (j = 0; j < 7-1 - i; j++)
{
printf(" ");
}
//打印'*'
for (j = 0; j < 2 * i + 1; j++)
{
printf("*");
}
printf("\n");
}
//下半部分
//因为第七行上半部分已完成,因此下半部分只需打印六行
for (i = 0; i < 7-1; i++)
{
//打印'空格'
for (j = 0; j <=i; j++)
{
printf(" ");
}
//打印'*'
for (j = 0; j < 2 * (7-1-i)-1; j++)
{
printf("*");
}
printf("\n");
}
return 0;
}
打印水仙花数
//打印水仙花数
//严格意义来说,只有百位以上的数才有水仙花数
//因此我可以直接从100~100000
//水仙花数为:每位数的(该数某位次方)之和等于该数
#include<math.h>
int main()
{
int i = 0;
int sum = 0;
int a = 0;
int b = 0;
int c = 0;
int d = 0;
int e = 0;
//循环
for (i = 100; i <= 100000; i++)
{
//判断百位
if (i < 1000)
{
a = i % 10;
b = i / 10 % 10;
c = i / 100;
if (i == pow(a, 3) + pow(b, 3) + pow(c, 3))
{
printf("%d ", i);
}
}
//判断千位
else if (i < 10000)
{
a = i % 10;
b = (i / 10) % 10;
c = (i / 100) %10;
d = i / 1000;
if (i == (pow(a,4)+ pow(b, 4)+ pow(c, 4)+pow(d, 4)))
{
printf("%d ", i);
}
}
//判断万位
else if (i < 100000)
{
a = i % 10;
b = i / 10 % 10;
c = i / 100 % 10;
d = i / 10 % 10;
e = i / 10000;
if (i == pow(a, 5) + pow(b, 5) + pow(c, 5) + pow(d, 5) + pow(e, 5))
{
printf("%d ", i);
}
}
}
return 0;
}
计算求和
//计算求和
// 将第一次数字的值赋给b变量
//然后循环四次(a(数字)*10+2)
int main()
{
//输入数字
int a = 0;
scanf("%d", &a);
//利用循环
int i = 0;
int b = a;
int sum = 0;
for (i = 1; i <= 4; i++)
{
//求和
sum = a * 10 + 2;
a = sum;
b += a;
}
printf("%d\n", b);
return 0;
}