42.编写一个函数 int Count(double a[],int n),统计出具有n个元素的一维数组中大于等于所有元素平均值的元素个数并返回这个值。注意:请使用 for 循环实现该函数。
#include<stdio.h>
#define N 10
int Count(double a[], int n)
{
int i = 0,j=0;
double sum = 0,aver=0;
for (i = 0; i < n; i++)
{
sum += a[i];
}
aver = sum / n;
for (i = 0; i < n; i++)
{
if (a[i] >= aver)j++;
}
return j;
}
int main()
{
double a[N];
printf("请输入%d个数:",N);
for (int i = 0; i < N; i++)
{
scanf_s("%f", &a[i]);
}
Count(a, N);
printf("大于等于平均值的数有%d个\n", Count(a, N));
return 0;
}
47.请编写一个函数 comm(int n,int k),用递归算法计算从n个人中选择k个人组成一个委员会的不同组合数
#include<stdio.h>
int com(int n, int k)
{
if (k > n)
return 0;
else if (k == n || k == 0)
return 1;
else
return com(n - 1, k) + com(n - 1, k - 1);
}
int main()
{
int n, k;
printf("总共的人数:");
scanf_s("%d", &n);
printf("选择的人数:");
scanf_s("%d", &k);
printf("组合数有:%d", com(n, k));
return 0;
}
51.将数组a[n]的每一个元素依次循环向后移动一位
#include<stdio.h>
#define n 10
int main()
{
int i = 0, a[n],temp;
printf("请输入数组中的%d元素:", n);
for (i = 0; i < n; i++)
{
scanf_s("%d", &a[i]);
}
temp = a[n - 1];
for (i = n - 2; i >= 0; i--)
{
a[i+1] = a[i];
}
a[0] = temp;
printf("\n变换之后的数组:");
for (i = 0; i < n; i++)
{
printf("%d ", a[i]);
}
return 0;
}
53.编写函数,给出年、月、日后,求该日是该年的第几天。
#include <stdio.h>
int leap_year(int year)
{
if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)
{
return 1;
}
else
return 0;
}
int md(int year, int month)
{
if (month == 1 || month == 3 || month == 5 || month == 7 || month == 8 || month == 10 || month == 12)
{
return 31;
}
if (month == 4 || month == 6 || month == 9 || month == 11)
{
return 30;
}
if (month == 2 && leap_year(year) == 1)
{
return 29;
}
if (month == 2 && leap_year(year) == 0)
{
return 28;
}
}
int sd(int year, int month, int day)
{
int i = 0;
int sum = 0;
for (i = 1; i < month; i++)
{
sum = sum + md(year, i);
}
sum = sum + day;
return sum;
}
int main()
{
int sum = 0;
int y = 0;
int m = 0;
int d = 0;
printf("请分别输入年、月、日:");
scanf_s("%d%d%d", &y, &m, &d);
sum = sd(y, m, d);
printf("%d", sum);
return 0;
}