第三章课后作业 0223966--邬宇腾

 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;
}

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值