zoukankan      html  css  js  c++  java
  • C语言习题解答:求某一天为一年中的第几天

    题目:本题目为谭浩强版C语言教材第11章《结构体和共用体》的课后习题第2题。要求:定义一个结构体变量(包括年、月、日),由主函数传递年月日到一个函数,计算出该日在本年度中是第几天。注意闰年与否。

    解决方法:反正闲着也是闲着,我就写了下,如下:

    View Code
    #include<stdio.h>
    struct riqi
    {
        int year;
        int month;
        int day;
    };
    void main()
    {
        int cau(int i,int j,int k);
        struct riqi aday;
        printf("Please input year:\n");
        scanf("%d",&aday.year);
        printf("Please input month:\n");
        scanf("%d",&aday.month);
        printf("Please input day:\n");
        scanf("%d",&aday.day);
        cau(aday.year,aday.month,aday.day);
    }
    int cau(int i,int j,int k)
    {
        if((i%400&&i%4)==0)
        {
            if(j<=2)
            {
                switch(j)
                {
                case 1:    printf("这是第%d天!\n",k);break;
                case 2:printf("这是第%d天!\n",k+31);break;
                default:;
                }
            }
            else if(j<=7)
            {
                if(j%2==0)
                {
                    printf("这是第%d天!\n",j/2*31+(j-2)/2*30+k-1);
                }
                else
                {
                    printf("这是第%d天!\n",(j-1)/2*(31+30)+k-1);
                }
            }
            else
            {
                if(j%2==0)
                {
                    printf("这是第%d天!\n",j/2*31+(j-2)/2*30+k-1);
                }
                else
                {
                    printf("这是第%d天!\n",(j+1)/2*31+(j-3)/2*30+k-1);
                }
            }
        }
        else
        {
            if(j<=2)
            {
                switch(j)
                {
                case 1:    printf("这是第%d天!\n",k);break;
                case 2:printf("这是第%d天!\n",k+31);break;
                default:;
                }
            }
            else if(j<=7)
            {
                if(j%2==0)
                {
                    printf("这是第%d天!\n",j/2*31+(j-2)/2*30+k-2);
                }
                else
                {
                    printf("这是第%d天!\n",(j-1)/2*(31+30)+k-2);
                }
            }
            else
            {
                if(j%2==0)
                {
                    printf("这是第%d天!\n",j/2*31+(j-2)/2*30+k-2);
                }
                else
                {
                    printf("这是第%d天!\n",(j+1)/2*31+(j-3)/2*30+k-2);
                }
            }
        }
    }

    因为比较简单,所以就没有注释了,呵呵。

    当然后来我看了下教程,对比了一下,发现它的更加简单,简单的原因是因为他将每个月的天数放到了一个数组中,如day_tab={0,31,28,31,30,31,30,31,31,30,31,30,31}

    其实这样写主要的问题就是七月和八月居然是连着两个月都是月大,所以没办法,他这种我觉得更好一些了,不过,我的也没有错哦!

    由此可知:条条大路通罗马啊!!

    鹜落霜洲,雁横烟渚,分明画出秋色。暮雨乍歇,小楫夜泊,宿苇村山驿。何人月下临风处,起一声羌笛。离愁万绪,闲岸草、切切蛩吟似织。 为忆芳容别后,水遥山远,何计凭鳞翼。想绣阁深沉,争知憔悴损,天涯行客。楚峡云归,高阳人散,寂寞狂踪迹。望京国。空目断、远峰凝碧。
  • 相关阅读:
    Redis安装部署
    传输方式Topic和Queue的对比
    Hudson配置及使用
    linux 绿色版 bes 6.6服务安装
    LINUX磁盘管理
    并发用户数与 TPS 之间的关系
    性能测试场景
    计算并发用户数的五种方法
    让selenium自动化脚本运行的更快的技巧
    Jmeter学习
  • 原文地址:https://www.cnblogs.com/thunderest/p/3038071.html
Copyright © 2011-2022 走看看