1.杨辉三角打印
#include<stdio.h>
int main()
{
int n=10;/*假设打印10阶杨辉三角*/
int arr[10][10];
int i,j, k;
for (i = 0; i < 10; i++)/*打印行数*/
{
for (j = 0; j <= i; j++)/*打印列数*/
{
if (j==i || j == 0)
{
arr[i][j] = 1;/*每行最两边为1*/
}
else if(i>1)
{
arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1];/*杨辉三角特点*/
}
printf("%-4d", arr[i][j]);
}
printf("\n");
}
return 0;
}
2.打印一个数各个位数之和
#include<stdio.h>
int DigitSum(int n)
{
if (n < 10)
return n;
else
return n % 10 + DigitSum(n / 10);
}/*利用递推依次得到一个数各位数的和*/
int main()
{
int i = 0;
scanf("%d", &i);
int sum = DigitSum(i);
printf("%d", sum);
return 0;
}
3.水仙花数(指一个 n 位正整数,其各位数字的 n 次幂之和等于该数本身)
法一
#include<stdio.h>
#include<Math.h>
int main()
{
int i, t;
for (i = 0; i < 99999; i++)
{
t = i;
int count = 0;
while (t)
{
count++;
t /= 10;
}/*确认位数*/
t = i;
int sum = 0;
while (t)
{
sum += pow(t % 10, count);/*每一位的n次方幂和*/
t /= 10;/*以便得到每一位数*/
}
if (sum == i)/*“水仙花数”的判断*/
{
printf("%d\n", i);
}
}
return 0;
}
法二
#include<stdio.h>
#include<Math.h>
int main()/*以三位数为例*/
{
int i, j, k, m, n;
for (i=1;i<10;i++)
for(j=0;j<10;j++)
for (k = 0; k < 10; k++)/*分别创建变量来表示三位数每一位*/
{
m = pow(i, 3) + pow(j, 3) + pow(k, 3);
n = i * 100 + j * 10 + k;
if (m == n)
{
printf("%d ", n);
}
}
return 0;
}
4.左旋字符(例如ABCD左旋一次变成BCDA)
#include<stdio.h>
#include<string.h>
int main()
{
char arr[] = "ABCDEF";
int len = strlen(arr);
int i, j, n, t;
printf("输入左移次数:");
scanf("%d",&n);
for (i = 1; i <= n; i++)
{
t = arr[0];
for (j = 0; j <= len - 2; j++)
{
arr[j] = arr[j + 1];/*后面字符下标依次往前进1*/
}
arr[len - 1] = t;/*将左旋字符放到字符串后面*/
}
for (i = 0; i < len; i++)
{
printf("%c", arr[i]);
}
return 0;
}