//使用指針列印數組内容
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;
}