解决一个问题需要算法的支持,今后当遇到类似的问题就可以利用这些小程序的算法思想解决了。
互换两个数字
# include <stdio.h>
void swap_3(int * p, int * q) //形参名字是p和q,接收实参数据的是p和q,而不是*p和*q
{
int t;
t = *p; *p = *q; *q = t;
}
int main(void)
{
int a = 3;
int b = 5;
swap_3(&a, &b);
printf("a = %d, b = %d\n", a, b);
return 0;
}
有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
#include"stdio.h"
#include"conio.h"
main()
{
inti,j,k;
printf("\n");
for(i=1;i<5;i++) /*以下为三重循环*/
for(j=1;j<5;j++)
for (k=1;k<5;k++)
{
if (i!=k&&i!=j&&j!=k) /*确保i、j、k三位互不相同*/
printf("%d,%d,%d\n",i,j,k);
}
getch();
}
求1到n之间奇数的平均值
# include <stdio.h>
int main(void)
{
int i;
int sum = 0;
int cnt = 0;
float avg;
for (i=1; i<n+1; ++i)
{
if (i%2 == 1)
{
sum += i;
++cnt;
}
}
avg = 1.0*sum / cnt; //1.0默认是double类型
printf("sum = %d\n", sum);
printf("cnt = %d\n", cnt);
printf("avg = %f\n", avg);
return 0;
}
|
|