c++的一道题...已知1900年1月1日是星期一, 输入n, 编程求自该系统日期变为1900开始的第n天的年月日及星期

问题已关闭
代为完成的个人任务
提问需要满足:其他人可能遇到相似问题,或问题的解决方法对其他人有所助益。如果通过其他方式解决遇到困难,欢迎提问并说明你的求知过程。
C 语言中求某一天是日历上第几周怎么计算?
用c语言编程,只知道年月日,星期几,那么怎么计算某一天是第几周呢?
参考 Stackoverflow:使用 C 标准库 time.h 就可以完成这个计算。示例代码如下(来自上面链接)#include &stdio.h&
#include &string.h&
#include &time.h&
main(void)
struct tm tm;
char timebuf[64];
// Zero out struct tm
memset(&tm, 0, sizeof(struct tm));
// November 4,
tm.tm_sec = 0;
tm.tm_min = 0;
tm.tm_hour = 23;
tm.tm_mday = 4;
tm.tm_mon = 10;
tm.tm_year = 108;
// Call mktime to recompute tm.tm_wday and tm.tm_yday
mktime(&tm);
if (strftime(timebuf, sizeof(timebuf), "%W", &tm) != 0) {
printf("Week number is: %s\n", timebuf);
1、知道年月日,可以计算这个日期是这一年的第几天m,也就是减去1月1日,例如:2月2日是这一年的第33天
2、将得到的天数m除以7,取整,得到过去了多少周n
3、将得到的天数m对7取余,与给定日期是星期几做对比,可以判断出是否出现了跨周的情况,如果出现了,再将2中得到的n加1
这个程序计算该天是该年的第几天
#include&stdio.h&
#include&stdlib.h&
#define ISLEAPYEAR(year) (year%400==0||year%4==0&&year%100!=0)
int which_day(int y,int m,int d);
int which_day(int y,int m,int d)
int year=y;
int sum=0;
int Y[12]={31,0,31,30,31,30,31,31,30,31,30,31};
if(ISLEAPYEAR(year))
for(i=0;i&m-1;i++)
sum+=Y[i];
return sum;
计算该年有多少天
#include&stdio.h&
#include&stdlib.h&
#define ISLEAPYEAR(year) (year%400==0||year%4==0&&year%100!=0)
int Count_sumday(int y);
int which_day(int y,int m,int d);
int Count_sumday(int y);
int Count_sumday(int y)
int year=y;
int sum_day=0;
int Y[12]={31,0,31,30,31,30,31,31,30,31,30,31};
if(ISLEAPYEAR(year))
for(i=0;i&12;i++)
sum_day+=Y[i];
return sum_day;
计算任意一天相隔多少天?得到相差
#include&stdio.h&
#include&stdlib.h&
#define ISLEAPYEAR(year) (year%400==0||year%4==0&&year%100!=0)
int which_day(int y,int m,int d);
int Count_sumday(int y);
int Between_days(int year,int month,int day);
int Between_days(int year,int month,int day)
int ini_y=1900,ini_m=1,ini_d=1;
int s_y,s_year,sum_y,sum_year;
int gap,i;
int sum_day_between_years=0;
s_y=which_day(ini_y,ini_m,ini_d);
s_year=which_day(year,month,day);
sum_year=Count_sumday(year);
sum_y=Count_sumday(ini_y);
if(ini_y==year)
//先计算y,m,d是该年的第几天,然后计算year,month,day是该年的第几天。最后两个天数相减
gap = s_y - s_year;
//如果两个年份相差1年
if((ini_y-year)==1)
gap = sum_year - s_year + s_y;
//两个年份相差不止一年,把中间相差的年份相加
for(i=(ini_y+1);i&year;i++)
sum_day_between_years += Count_sumday(i);
//printf("sum_day_between_years is %d",sum_day_between_years);
gap = sum_year - s_year+ sum_day_between_years + s_y;
printf("s_y=which_day(y,m,d):%d\n"
"s_year=which_day(year,month,day):%d\n"
"sum_year=Count_sumday(year):%d\n"
"sum_y=Count_sumday(y):%d\n",s_y,s_year,sum_y,sum_year);
return gap;
计算该天是星期几的主函数.
#include&stdio.h&
#include&stdlib.h&
int which_day(int y,int m,int d);
int Count_sumday(int y);
int Between_days(int year,int month,int day);
int main(int argv,char* argc[])
int year,month,day;
char weekday[]={'1','2','3','4','5','6','7'};
int gap=0;
int w_day=0;
printf("Please input year,month,day:\n");
scanf("%d %d %d",&year,&month,&day);
gap=Between_days(year,month,day);
w_day=(gap%7+1)%7;
printf("This day is %d and the gap weeks is:%d\n",w_day,gap);
已有帐号?
无法登录?
社交帐号登录您所在的位置: &
2007年11月程序员下午试题(1)
2007年11月程序员下午试题(1)
国家软考办
国家软考办
本文为2007年11月程序员下午试题。
试题一(共15分)
阅读以下说明和流程图,填补流程图中的空缺(1)~(5),将解答填入答题纸的对应栏内。
某单位动态收集的数据中常包含重复的数据,所以需要进行处理,使得重复的数据仅出现一次。下面流程图的功能是:在n(n≥1)个数据 中,选出其中所有不重复的k个数据,置于原来前k个数据的位置上。
该流程图的算法如下:第1个数据必然被选出,然后从第2个数据开始,逐个考察其余的数据。假设 (m≥1)是已经选出的、不重复的数据,则对于数据 ,将其依次与 进行比较,若没有发现与之相同者,则 被选出并置于 的位置上;否则对498)this.width=498;' onmousewheel = 'javascript:return big(this)' height=25 alt="" src="/files/uploadimg/512742.jpg" width=20 border=0>不做处理。
例如,如下10个数据:
5,2,2,7,4,4,7,1,9,1&&& (n=10)
经过上述算法处理后的结果为:
5,2,7,4,1,9&&&&&&&&&&&&&&& (k=6)
注:循环开始的说明按照"循环变量名:循环初值,循环终值,增量"格式描述。试题二(共15分)
阅读以下说明和C语言函数,将应填入 (n) 处的字句写在答题纸的对应栏内。
已知日是星期一,下面的函数count_5_13(int year)用于计算给定的年份year中有几个"黑色星期五"。"黑色星期五"指既是13日又是星期五的日期。
函数count_5_13(int year)首先算出年份year的1月13日是星期几,然后依次计算每个月的13日是星期几,若是星期五,则计数。
程序中使用了函数isLeapYear(int year),其功能是判断给定年份是否为闰年,返回值为1(或0)分别表示year是(或不是)闰年。
[C语言函数]
int count_5_13(int year) {&&&&&&& /* date为0表示星期日,为1~6分别表示星期一至星期六 */long days = 0;&& /* days记录天数 */int m, y, c = 0; /* c用于表示黑色星期五的个数 */if (year & 1900)&&&& return -1;/*计算从日起,至给定年份year的1月13日间隔的天数*/days = 12;for (y = 1900; y & y++) {days += 365;if (isLeapYear(y))&&& (1)& ;}date = ((days % 7) + 1) % 7;& /* 算出给定年份year的1月13日是星期几 */c = (& (2)& ) ? 1 : 0;for(m = 1;&&& (3)& ; m++)& {switch (m) {&case 1: case 3: case 5: case 7: case 8: case 10: case 12: days = 31;&case 4: case 6: case 9: case 11: days = 30;&case 2: days = 28;if (& (4)& )&&& days = 29;}/* end of switch*/date =((days % 7) +&& (5)& ) % 7;if (date == 5) &c++;} /* end of for*/& }试题三(共15分)
阅读以下说明和C语言程序,将应填入 (n) 处的字句写在答题纸的对应栏内。
某电信公司记录了每个用户的详细通话情况(每次通话数据记录在一行),现将某用户某月的通话数据存入一个文本文件"dial.txt",其数据格式如下:
拨入或拨出标记 通话开始时间 通话结束时间 对方号码
注1:数据字段以一个空格作为分隔符。
注2:拨入和拨出标记均为小写字母。拨入标记为"i",表示其他用户呼叫本机,本机用户不需付费;拨出标记为"o",表示本机呼叫其他用户,此时本机用户需要付费。
注3:通话开始和结束时间的格式均为:HH:MM:SS。其中HH表示小时,取值00~23;MM表示分钟,取值00~59;SS表示秒,取值00~59。从通话开始到结束这段时间称为通话时间,假定每次通话时间以秒为单位,最短为1秒,最长不超过24小时。
注4:跨月的通话记录计入下个月的通话数据文件。
例如"o 23:01:12 00:12:15 …"表示本次通话是本机呼叫其他用户,时间从23时01分12秒至次日的0时12分15秒,通话时间为71分03秒。
下面程序的功能是计算并输出该用户本月电话费(单位:元)。
通话计费规则为:
1. 月通话费按每次通话费累加;
2. 每次的通话费按通话时间每分钟0.08元计算,不足1分钟时按1分钟计费。
对于每次的拨出通话,程序中先分别计算出通话开始和结束时间相对于当日0点0分0秒的时间长度(以秒为单位),然后算出本次通话时间和通话费。
例如,若输入文件dial.txt的数据如下所示,则输出fee = 7.44。
o 14:05:23 14:11:25 i 15:10:00 16:01:15 o 10:53:12 11:07:05 o 23:01:12 00:12:15
[C程序代码]#include
FILE *int main(){char str[80];int h1,h2,m1,m2,s1,s2;long t_start,t_end,double fee = 0;fin = fopen("dial.txt","r");if (!fin)return -1;
while (!feof(fin)) {& if (!fgets(str,80,fin))&if (& (1)& )&&
h1 = (str[2] - 48) * 10 + str[3] - 48;m1 = (str[5] - 48) * 10 + str[6] - 48;s1 = (str[8] - 48) * 10 + str[9] - 48;
h2 = (str[11] - 48) * 10 + str[12] - 48;m2 = (str[14] - 48) * 10 + str[15] - 48;s2 = (str[17] - 48) * 10 + str[18] - 48;&&& t_start = h1*60*60 + m1*60 + s1; /* 通话开始时间 */t_end = h2*60*60 + m2*60 + s2;&& /* 通话结束时间 */if (& (2)& )& /* 若通话开始和结束时间跨日 */interval =&& (3)&& - t_start + t_elseinterval = t_end - t_c =&& (4)& ;&&& /* 计算完整分钟数表示的通话时间 */if (interval % 60)(5)& ;fee += c * 0.08;}fclose(fin);printf("fee = %.2lf\n",fee);return 0;}试题四(共15分)
阅读以下说明和C语言函数,将应填入 (n) 处的字句写在答题纸的对应栏内。
已知包含头结点(不存储元素)的单链表的元素已经按照非递减方式排序,函数compress(NODE *head)的功能是去掉其中重复的元素,使得链表中的元素互不相同。
处理过程中,当元素重复出现时,保留元素第一次出现所在的结点。
图4-1(a)、(b)是经函数compress()处理前后的链表结构示例图。
链表的结点类型定义如下:
typedef struct Node {struct Node *}NODE;
[C语言函数]void compress(NODE *head) {& NODE *ptr,*q;ptr =&& (1)& ;&& /* 取得第一个元素结点的指针 */while (& (2)&& && ptr -& next)& {q = ptr -&while(q &&&& (3)& ) {& /* 处理重复元素 */(4)&& = q -&free(q);q = ptr -&}(5)&& = ptr -&}/* end of while */}/* end of compress */
内容导航&第 1 页: &第 2 页:
关于&&&&&&的更多文章
新手程序员你们好!你是否做好了进入编程世界的准备呢?要知道,
聘请技术专家,推出精品IT视频课程,支持在线观看、答疑。
讲师: 5人学习过讲师: 17人学习过讲师: 16人学习过
市面的图书鱼龙混杂,各式各样,听起名字好像都很不错
2010年上半年计算机技术与软件专业技术资格(水平)考
2010年上半年的全国计算机等级考试将在3月27日举行,5
本书使用通俗易懂的语言,通过大量的实例,从实际应用的角度出发,全面系统地介绍了网络服务操作系统平台、电子邮件系统、Web站
51CTO旗下网站}

我要回帖

更多关于 excel日期变成1900 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信