亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? xwzhang.c

?? 基于51的陰陽歷轉(zhuǎn)換程序(c語言)
?? C
?? 第 1 頁 / 共 2 頁
字號:
調(diào)用函數(shù)后,原有數(shù)據(jù)不變,讀c_moon,year_moon,month_moon,day_moon得出陰歷BCD數(shù)據(jù)
*/
bit c_moon;
data uchar year_moon,month_moon,day_moon,week;

/*子函數(shù),用于讀取數(shù)據(jù)表中農(nóng)歷月的大月或小月,如果該月為大返回1,為小返回0*/
unsigned char get_moon_day(uchar month_p,uint table_addr)
{
unsigned char temp;  

    switch (month_p){
        case 1:{if((year_code[table_addr]&0x08) == 0) return(0);
				else return(1);}
        case 2:{if((year_code[table_addr]&0x04) == 0) return(0);
				else return(1);}
        case 3:{if((year_code[table_addr]&0x02) == 0) return(0);
				else return(1);}
        case 4:{if((year_code[table_addr]&0x01) == 0) return(0);
				else return(1);}
        case 5:{if((year_code[table_addr+1]&0x80) == 0) return(0);
				else return(1);}
        case 6:{if((year_code[table_addr+1]&0x40 )== 0) return(0);
				else return(1);}
        case 7:{if((year_code[table_addr+1]&0x20 )== 0) return(0);
				else return(1);}
        case 8:{if((year_code[table_addr+1]&0x10) == 0) return(0);
				else return(1);}
        case 9:{if((year_code[table_addr+1]&0x08) == 0) return(0);
				else return(1);}
        case 10:{if((year_code[table_addr+1]&0x04) == 0) return(0);
				else return(1);}
        case 11:{if((year_code[table_addr+1]&0x02) == 0) return(0);
				else return(1);}
        case 12:{if((year_code[table_addr+1]&0x01) == 0) return(0);
				else return(1);}
        case 13:{temp=year_code[table_addr+2]&0x80;
             if (temp==0)return(0);else return(1);}
    }
}

/*
函數(shù)功能:輸入BCD陽歷數(shù)據(jù),輸出BCD陰歷數(shù)據(jù)(只允許1901-2099年)
調(diào)用函數(shù)示例:Conversion(c_sun,year_sun,month_sun,day_sun)
如:計算2004年10月16日Conversion(0,0x4,0x10,0x16);
c_sun,year_sun,month_sun,day_sun均為BCD數(shù)據(jù),c_sun為世紀標志位,c_sun=0為21世
紀,c_sun=1為19世紀
調(diào)用函數(shù)后,原有數(shù)據(jù)不變,讀c_moon,year_moon,month_moon,day_moon得出陰歷BCD數(shù)據(jù)
*/
void Conversion(bit c,uchar year,uchar month,uchar day)
{                         //c=0 為21世紀,c=1 為19世紀 輸入輸出數(shù)據(jù)均為BCD數(shù)據(jù)
    uchar temp1,temp2,temp3,month_p;
    uint temp4,table_addr;
    unsigned char flag2,flag_y;
    temp1=year/16;   //BCD->hex 先把數(shù)據(jù)轉(zhuǎn)換為十六進制
    temp2=year%16;
    year=temp1*10+temp2;
    temp1=month/16;
    temp2=month%16;
    month=temp1*10+temp2;
    temp1=day/16;
    temp2=day%16;
    day=temp1*10+temp2;

    //定位數(shù)據(jù)表地址
    if(c==0){                   
        table_addr=(year+0x64-1)*0x3;
    }
    else {
        table_addr=(year-1)*0x3;
    }
    //定位數(shù)據(jù)表地址完成

    //取當年春節(jié)所在的公歷月份
    temp1=year_code[table_addr+2]&0x60; 
    temp1=_cror_(temp1,5);
    //取當年春節(jié)所在的公歷月份完成

    //取當年春節(jié)所在的公歷日
    temp2=year_code[table_addr+2]&0x1f; 
    //取當年春節(jié)所在的公歷日完成

    // 計算當年春年離當年元旦的天數(shù),春節(jié)只會在公歷1月或2月
    if(temp1==0x1){  
        temp3=temp2-1;  
    }  
    else{
        temp3=temp2+0x1f-1;        
    }
    // 計算當年春年離當年元旦的天數(shù)完成

    //計算公歷日離當年元旦的天數(shù),為了減少運算,用了兩個表
    //day_code1[9],day_code2[3]
    //如果公歷月在九月或前,天數(shù)會少于0xff,用表day_code1[9],
    //在九月后,天數(shù)大于0xff,用表day_code2[3]
    //如輸入公歷日為8月10日,則公歷日離元旦天數(shù)為day_code1[8-1]+10-1
    //如輸入公歷日為11月10日,則公歷日離元旦天數(shù)為day_code2[11-10]+10-1
    if (month<10){ 
        temp4=day_code1[month-1]+day-1;
    }
    else{
        temp4=day_code2[month-10]+day-1;
    }
    if ((month>0x2)&&(year%0x4==0)){  //如果公歷月大于2月并且該年的2月為閏月,天數(shù)加1
        temp4+=1;
    }
    //計算公歷日離當年元旦的天數(shù)完成

    //判斷公歷日在春節(jié)前還是春節(jié)后
    if (temp4>=temp3){ //公歷日在春節(jié)后或就是春節(jié)當日使用下面代碼進行運算
        temp4-=temp3;
        month=0x1;
        month_p=0x1;  //month_p為月份指向,公歷日在春節(jié)前或就是春節(jié)當日month_p指向首月
        flag2=get_moon_day(month_p,table_addr); //檢查該農(nóng)歷月為大小還是小月,大月返回1,小月返回0
        flag_y=0;
        if(flag2==0)temp1=0x1d; //小月29天
        else temp1=0x1e; //大小30天
        temp2=year_code[table_addr]&0xf0;
        temp2=_cror_(temp2,4);  //從數(shù)據(jù)表中取該年的閏月月份,如為0則該年無閏月右移4位
        while(temp4>=temp1){
            temp4-=temp1;
            month_p+=1;
            if(month==temp2){
            flag_y=~flag_y;
            if(flag_y==0)month+=1;
            }
            else month+=1;
            flag2=get_moon_day(month_p,table_addr);
            if(flag2==0)temp1=0x1d;
            else temp1=0x1e;
        }
        day=temp4+1;
    }
    else{  //公歷日在春節(jié)前使用下面代碼進行運算
        temp3-=temp4;
        if (year==0x0){year=0x63;c=1;}
        else year-=1;
        table_addr-=0x3;
        month=0xc;
        temp2=year_code[table_addr]&0xf0;
        temp2=_cror_(temp2,4);
        if (temp2==0)month_p=0xc; 
        else month_p=0xd; //
        /*
        month_p為月份指向,如果當年有閏月,一年有十三個月,月指向13,
無閏月指向12
        */
        flag_y=0;
        flag2=get_moon_day(month_p,table_addr);
        if(flag2==0)temp1=0x1d;
        else temp1=0x1e;
        while(temp3>temp1){
            temp3-=temp1;
            month_p-=1;
            if(flag_y==0)month-=1;
            if(month==temp2)flag_y=~flag_y;
            flag2=get_moon_day(month_p,table_addr);
            if(flag2==0)temp1=0x1d;
            else temp1=0x1e;
         }
        day=temp1-temp3+1;
    }
    c_moon=c;                 //HEX->BCD ,運算結(jié)束后,把數(shù)據(jù)轉(zhuǎn)換為BCD數(shù)據(jù)
    temp1=year/10;
    temp1=_crol_(temp1,4);
    temp2=year%10;
    year_moon=temp1|temp2;
    temp1=month/10;
    temp1=_crol_(temp1,4);
    temp2=month%10;
    month_moon=temp1|temp2;
    temp1=day/10;
    temp1=_crol_(temp1,4);
    temp2=day%10;
    day_moon=temp1|temp2;
}

/*
函數(shù)功能:輸入BCD陽歷數(shù)據(jù),輸出BCD星期數(shù)據(jù)(只允許1901-2099年)
調(diào)用函數(shù)示例:Conver_week(c_sun,year_sun,month_sun,day_sun)
如:計算2004年10月16日Conversion(0,0x4,0x10,0x16);
c_sun,year_sun,month_sun,day_sun均為BCD數(shù)據(jù),c_sun為世紀標志位,c_sun=0為21世
紀,c_sun=1為19世紀
調(diào)用函數(shù)后,原有數(shù)據(jù)不變,讀week得出陰歷BCD數(shù)據(jù)
*/
code uchar table_week[12]={0,3,3,6,1,4,6,2,5,0,3,5}; //月修正數(shù)據(jù)表
/*
算法:日期+年份+所過閏年數(shù)+月較正數(shù)之和除7 的余數(shù)就是星期但如果是在
閏年又不到3 月份上述之和要減一天再除7
星期數(shù)為0
*/
void Conver_week(bit c,uchar year,uchar month,uchar day)
{//c=0 為21世紀,c=1 為19世紀 輸入輸出數(shù)據(jù)均為BCD數(shù)據(jù)
    uchar temp1,temp2;
    temp1=year/16;   //BCD->hex 先把數(shù)據(jù)轉(zhuǎn)換為十六進制
    temp2=year%16;
    year=temp1*10+temp2;
    temp1=month/16;
    temp2=month%16;
    month=temp1*10+temp2;
    temp1=day/16;
    temp2=day%16;
    day=temp1*10+temp2;
    if (c==0){year+=0x64;}  //如果為21世紀,年份數(shù)加100
    temp1=year/0x4;  //所過閏年數(shù)只算1900年之后的
    temp2=year+temp1;
    temp2=temp2%0x7;  //為節(jié)省資源,先進行一次取余,避免數(shù)大于0xff,避免使用整型數(shù)據(jù)
    temp2=temp2+day+table_week[month-1];
    if (year%0x4==0&&month<3)temp2-=1;
    week=temp2%0x7;
}

//test
uchar c_sun,year_sun,month_sun,day_sun;
void main(){
c_sun=0;
year_sun=0x8;
month_sun=0x6;
day_sun=0x25;
//Conver_week(c_sun,year_sun,month_sun,day_sun);
Conversion(c_sun,year_sun,month_sun,day_sun);
while(1);
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
视频一区二区欧美| av在线不卡免费看| jlzzjlzz亚洲日本少妇| 欧美日韩你懂的| 国产精品久久久久久久久久免费看 | 国产成人av电影在线观看| 一区二区三区中文免费| 日本不卡在线视频| 91日韩在线专区| 日本一区二区三区dvd视频在线| 亚洲chinese男男1069| 不卡一区二区在线| 国产日产欧美一区二区三区| 日本怡春院一区二区| 欧洲av一区二区嗯嗯嗯啊| 国产精品乱人伦| 国产一区二区不卡| 日韩欧美激情四射| 男人操女人的视频在线观看欧美 | 欧美日韩国产高清一区二区| 亚洲青青青在线视频| 国产伦精品一区二区三区视频青涩 | 亚洲精选视频免费看| 99久久精品99国产精品| 国产视频视频一区| 国产成人在线色| 久久久国产精品麻豆| 国产一区美女在线| 久久婷婷国产综合国色天香| 国产尤物一区二区在线| 久久综合久久综合久久综合| 精品一二三四区| 精品国产欧美一区二区| 久久精品999| 国产亚洲精品中文字幕| 国产精品18久久久久久vr| 久久亚洲一区二区三区四区| 国产一区二区福利| 欧美国产日韩一二三区| 高清国产一区二区| 欧美国产成人精品| 色素色在线综合| 爽好多水快深点欧美视频| 91精品中文字幕一区二区三区| 午夜影院在线观看欧美| 日韩精品专区在线| 国产精品一区二区久久不卡 | 99久久伊人网影院| 一区二区三区在线观看欧美| 欧美性高清videossexo| 蜜桃久久精品一区二区| 久久午夜免费电影| 日本道精品一区二区三区| 午夜精品久久久久久久99水蜜桃 | 国产精品久线在线观看| 欧美丝袜第三区| 久久国产精品色婷婷| 欧美激情一区不卡| 欧美精品九九99久久| 黑人巨大精品欧美一区| 一区二区中文字幕在线| 欧美片在线播放| 国产麻豆精品在线| 亚洲在线中文字幕| 久久综合狠狠综合久久综合88| 成人ar影院免费观看视频| 亚洲va国产天堂va久久en| 国产亚洲欧美在线| 欧美久久一二区| 国产成人精品1024| 视频一区欧美精品| 国产欧美日韩激情| 欧美精品三级在线观看| 懂色av一区二区三区免费观看 | 亚洲欧洲日韩在线| 日韩视频在线一区二区| av电影在线观看不卡| 老汉av免费一区二区三区| 国产精品三级久久久久三级| 欧美一区二区三区四区高清| 91在线国产福利| 国产激情一区二区三区桃花岛亚洲| 一区二区三区欧美日| 欧美激情在线看| 精品免费99久久| 欧美日韩一区二区三区在线看| 国产99久久久精品| 久久97超碰国产精品超碰| 亚洲一区二区三区小说| 中文字幕欧美日韩一区| 日韩美女在线视频| 欧美乱妇15p| 色婷婷亚洲精品| 波多野结衣在线aⅴ中文字幕不卡| 日本色综合中文字幕| 亚洲一区中文在线| 亚洲人成在线播放网站岛国| 久久嫩草精品久久久精品| 91精品国产综合久久福利| 欧美亚洲一区二区在线| 色综合中文字幕国产| 国产一区二区三区不卡在线观看| 日韩精品1区2区3区| 五月婷婷激情综合网| 亚洲主播在线观看| 亚洲综合色视频| 亚洲一区二区三区在线播放| 亚洲综合图片区| 亚洲国产cao| 亚洲一区欧美一区| 亚洲综合丁香婷婷六月香| 亚洲欧美韩国综合色| 成人免费小视频| 亚洲欧美精品午睡沙发| 亚洲欧美日韩久久| 一区二区三区日韩欧美精品 | 精久久久久久久久久久| 久久草av在线| 国产乱子轮精品视频| 国产精品综合在线视频| 国产精品1区二区.| 91亚洲国产成人精品一区二区三 | 精品久久免费看| 久久精品视频在线免费观看| 337p粉嫩大胆色噜噜噜噜亚洲| 久久久久国产精品麻豆ai换脸| 国产视频视频一区| 亚洲欧洲另类国产综合| 亚洲综合免费观看高清在线观看| 亚洲香蕉伊在人在线观| 亚洲成人免费视| 国产在线播放一区| av激情成人网| 3d成人动漫网站| 精品国产乱码久久久久久图片| 日本一区二区视频在线| 一区二区欧美国产| 另类专区欧美蜜桃臀第一页| 成人午夜伦理影院| 欧美熟乱第一页| 久久久五月婷婷| 一区二区三区四区在线播放| 日本中文一区二区三区| 成人免费av网站| 欧美日韩久久一区| 精品噜噜噜噜久久久久久久久试看 | 一级做a爱片久久| 美脚の诱脚舐め脚责91| 成人污视频在线观看| 欧美久久婷婷综合色| 国产精品日韩成人| 午夜精品久久久久久久蜜桃app| 国产在线精品国自产拍免费| 91免费观看国产| 日韩欧美视频一区| 国产精品国产三级国产普通话99| 亚洲成人资源在线| 成人免费视频播放| 欧美一区二区三区啪啪| 中文字幕在线观看一区| 美女久久久精品| 色妞www精品视频| 久久精品夜色噜噜亚洲a∨| 亚洲高清免费视频| 99久久综合国产精品| 精品国产sm最大网站免费看| 亚洲一区免费观看| 99久久久国产精品免费蜜臀| 日韩欧美久久一区| 午夜影视日本亚洲欧洲精品| thepron国产精品| 精品国产成人系列| 天天亚洲美女在线视频| 色综合久久中文字幕综合网| 久久先锋影音av鲁色资源| 免费高清在线一区| 欧美日韩一级片在线观看| 日韩一区在线播放| 东方欧美亚洲色图在线| 久久亚洲综合av| 精品一二三四区| 91精品国产91久久久久久最新毛片| 亚洲精品一二三区| 99精品国产热久久91蜜凸| 国产三级精品视频| 国产酒店精品激情| 久久一二三国产| 久久99精品国产| 26uuu国产日韩综合| 极品少妇一区二区三区精品视频| 欧美剧在线免费观看网站 | 中文字幕一区二区三区不卡 | 欧美日韩精品电影| 亚洲一二三四在线观看| 色哟哟一区二区三区| 亚洲女子a中天字幕| 91免费版在线| 一区二区三区免费看视频| 在线免费观看一区| 亚洲精品免费播放|