关于C语言的几个问题

来源:百度知道 编辑:UC知道 时间:2024/05/26 06:46:32
1.给出年、月、日,计算该日是该年的第几天。
2.给出年份和天数,求出相应的月、日。
3.输入10 个学生5 门课的成绩,分别求:每个学生的平均分;每门课的平均分;按总成
绩的学生排名。
4.应用指针,编写堆栈的基本操作函数。
5.应用指针,编写队列的基本操作函数。
6.编写一程序,从标准输入键入n 行信息,并输出最后m 行信息。
7.编写一程序,能对输入的两个多项式进行加法运算。
8.输入15 个数存放在一个数组中。输入一个数,用二分(折半)查找法判断该数是否在数组中,若是则输出是数组中的第几个元素。
希望高手能帮我解答这几题
最好在一些程序后面有注释
谢谢!!

1:
#define START_YEAR 1950
#define END_YEAR 2050
int IsLeapYear(WORD iYear)
{return !(iYear%4)&&(iYear%100) || !(iYear%400);}
LONG CalcDateDiff(WORD iEndYear, WORD iEndMonth, WORD iEndDay,
WORD iStartYear, WORD iStartMonth, WORD iStartDay)
{
WORD monthday[]={0, 31, 59 ,90, 120, 151, 181, 212, 243, 273, 304, 334};

//计算两个年份1月1日之间相差的天数
LONG iDiffDays =(iEndYear - iStartYear)*365;
iDiffDays += (iEndYear-1)/4 - (iStartYear-1)/4;
iDiffDays -= ((iEndYear-1)/100 - (iStartYear-1)/100);
iDiffDays += (iEndYear-1)/400 - (iStartYear-1)/400;

//加上iEndYear年1月1日到iEndMonth月iEndDay日之间的天数
iDiffDays += monthday[iEndMonth-1] +
(IsLeapYear(iEndYear)&&iEndMonth>2? 1: 0);
iDiffDays += iEndDay;

//减去iStartYear年1月1日到iStartMonth月iStartDay日之间的天数
iDiffDays -= (monthday[iStartMonth-1] +
(IsLeapYear(iSta