青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

子彈 の VISIONS

NEVER back down ~~

C++博客 首頁 新隨筆 聯系 聚合 管理
  112 Posts :: 34 Stories :: 99 Comments :: 0 Trackbacks
#
// created by ztwaker on 2006-8-24
// Used for: count days
// No guarantees offered. Constructive comments to waker615@gmail.com

// 需求:計算兩個日期之間相距天數。
// 應用:倒計時等

#include <iostream>
#include <algorithm>
namespace date {

//#define min(a, b) (((a) > (b)) ? (b) : (a))
//#define max(a, b) (((a) > (b)) ? (a) : (b))
	
	class Bad_date {}; // exception throw
	class Bad_year  : public Bad_date {};
	class Bad_month : public Bad_date {};
	class Bad_day   : public Bad_date {};
	
    ??? static const int this_year = 2006;

	inline bool leapyear(int year)
	{
		//if (year > this_year)
		// 	throw Bad_year();
		
		return ((year % 100==0) ? (year % 400==0) : (year % 4==0));
	}
	
	inline int yday(int year)
	{
		//if (year > this_year)
		//	throw Bad_year();
		
		return (365 + leapyear(year));
	}
	
	inline int mday(int month, int year)
	{
		switch(month) {
		case 1: case 3: case 5: 
		case 7: case 8: case 10:
		case 12:
			return 31;
			
		case 4: case 6: case 9: 
		case 11: 
			return 30;
			
		case 2: 
			return 28 + leapyear(year);
			
		default:
			throw Bad_month();
		}
		
		throw Bad_month();
	}
	
	class Date{
		int y, m, d;
		
	public:
		Date(int year, int month, int day)
		{
			// check year/month/day available
			if (0 == year)
				throw Bad_year();

			if (1 > month || 12 < month)
				throw Bad_month();

			if (1 > day || mday(month, year) < day)
				throw Bad_day();
			
			y = year; m = month; d = day;
		}
		Date(const Date& rhs)
		{
			this->y = rhs.year();
			this->m = rhs.month();
			this->d = rhs.day();
		}		
		Date& operator=(const Date& rhs)
		{
			if (rhs == (*this))
				return (*this);
			
			this->y = rhs.year();
			this->m = rhs.month();
			this->d = rhs.day();
			
			return (*this);
		}
		int year () const { return y; }
		int month() const { return m; }
		int day  () const { return d; }
		
		int passday() const
		{
			int dpass = 0;
			for (int i = 1; i != m; ++i)
			{
				dpass += mday(i, y);
			}
			
			return (dpass + d);
		}

		friend std::ostream& operator<<(std::ostream& os, const Date& rhs);
		
		friend bool operator==(const Date& lhs, const Date& rhs);
		friend bool operator!=(const Date& lhs, const Date& rhs);
		friend bool operator< (const Date& lhs, const Date& rhs);
		friend bool operator> (const Date& lhs, const Date& rhs);
		friend bool operator<=(const Date& lhs, const Date& rhs);
		friend bool operator>=(const Date& lhs, const Date& rhs);
		
		friend int  distant(const Date& lhs, const Date& rhs);
	};

	inline std::ostream& operator<<(std::ostream& os, const Date& rhs)
	{
		return (os << rhs.y << "-" << rhs.m << "-" << rhs.d);
	}
	inline bool operator==(const Date& lhs, const Date& rhs)
	{
		return (lhs.y == rhs.y && lhs.m == rhs.m && lhs.d == rhs.d);
	}
	inline bool operator!=(const Date& lhs, const Date& rhs)
	{
		return (!(lhs==rhs));
	}
	inline bool operator<(const Date& lhs, const Date& rhs)
	{
		// compare year
		if (lhs.y < rhs.y)
		{
			return true;
		}
		else if (lhs.y == rhs.y)
		{
			// compare month
			if (lhs.m < rhs.m)
			{
				return true;
			}
			else if (lhs.m == rhs.m)
			{
				// compare day
				if (lhs.d < rhs.d)
					return true;
				else
					return false;
			}
			return false;
		}
		return false;
	}
	inline bool operator>(const Date& lhs, const Date& rhs)
	{
		// compare year
		if (lhs.y > rhs.y)
		{
			return true;
		}
		else if (lhs.y == rhs.y)
		{
			// compare month
			if (lhs.m > rhs.m)
			{
				return true;
			}
			else if (lhs.m == rhs.m)
			{
				// compare day
				if (lhs.d > rhs.d)
					return true;
				else
					return false;
			}
			return false;
		}
		return false;
	}
	inline bool operator<=(const Date& lhs, const Date& rhs)
	{
		return (!(lhs>rhs));
	}
	inline bool operator>=(const Date& lhs, const Date& rhs)
	{
		return (!(lhs<rhs));
	}
	
	int distant(const Date& lhs, const Date& rhs)
	{
		int distance = 0;
		const int lowyear  = std::min(lhs.y, rhs.y);
		const int highyear = std::max(lhs.y, rhs.y);
		for (int yn = lowyear; yn != highyear; ++yn)
		{
			distance += yday(yn);
		}
		
		return (
			distance - std::min(lhs, rhs).passday() 
			+ std::max(lhs, rhs).passday()
			);
	}
} // end of namespace date

void test()
{
	try {
		date::Date today(2006, 1, 29);    // 丙戌年春節
		date::Date deadline(2007, 2, 18); // 丁亥年春節
		std::cout << "From "<< today << " to " << deadline << " is ";
		std::cout << date::distant(today, deadline) << " days left.\n";
	}
	catch (date::Bad_year) {
		std::cout << "Bad year" << std::endl;
	}
	catch (date::Bad_month) {
		std::cout << "Bad month" << std::endl;
	}
	catch (date::Bad_day) {
		std::cout << "Bad day" << std::endl;
	}
	catch (date::Bad_date) {
		std::cout << "Bad date" << std::endl;
	}
}

int main()
{
    test();
    return 0;
}
posted on 2006-08-25 11:08 子彈のVISIONS 閱讀(1740) 評論(6)  編輯 收藏 引用

Feedback

# re: [OPPD] 計算兩個日期之間相距天數 2006-08-25 11:10 子彈
如果限于此需求,對于operator,僅重載">"也夠用了;甚至
copy constructor [Date(const Date& rhs)] 和operator = 也可以不提供。  回復  更多評論
  

# re: [OPPD] 計算兩個日期之間相距天數 2006-08-25 19:08 chenger
min和max兩個宏用標準庫提供的min和max算法代替更好些  回復  更多評論
  

# re: [OPPD] 計算兩個日期之間相距天數 2006-08-28 09:06 子彈
@chenger
贊成。

之前使用宏的原因是:VC6對generaic algorithms min and max支持不好。為了方便編譯而使用。

// 已經改用STL的算法min和max  回復  更多評論
  

# re: [OPPD] 計算兩個日期之間相距天數 2006-08-28 15:43 chenger
聽說VC6對C++標準的支持很不好,特別是template。居然連min max這樣的簡單模板函數都搞不定?
還是用g++或者vs2005得編譯器好  回復  更多評論
  

# re: [OPPD] 計算兩個日期之間相距天數 2006-08-29 08:58 子彈
@chenger

裝了SP6之后對template支持稍好  回復  更多評論
  

# re: [OPPD] 計算兩個日期之間相距天數 2006-08-30 16:25
scut師兄?支持一下!~  回復  更多評論
  


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品久久久久久久久免费桃花| 欧美视频在线观看 亚洲欧| 狠狠色狠色综合曰曰| 久久经典综合| 久久精品中文字幕一区二区三区| 国产一区香蕉久久| 欧美成人蜜桃| 欧美日韩精品一区二区三区| 亚洲天堂男人| 亚洲欧美中文字幕| 激情小说亚洲一区| 欧美激情在线播放| 欧美日韩精品免费观看视一区二区| 中文国产一区| 欧美一区二区三区精品| 在线看国产日韩| 亚洲精品资源美女情侣酒店| 国产精品福利在线| 卡通动漫国产精品| 欧美日本国产在线| 久久xxxx精品视频| 蜜臀99久久精品久久久久久软件| 夜夜嗨av一区二区三区四季av | 国产精品美女在线| 久久亚洲综合色| 欧美激情中文字幕乱码免费| 亚洲综合电影| 免费一级欧美片在线观看| 亚洲视频在线免费观看| 性欧美激情精品| 亚洲精品欧美激情| 亚洲视频在线观看三级| 亚洲国产精品热久久| 亚洲手机在线| 亚洲免费成人av电影| 欧美在线一级视频| 一区二区三区国产精华| 久久精品国产第一区二区三区| 亚洲伦理精品| 久久精品成人| 亚洲综合社区| 欧美精品免费观看二区| 久久综合伊人77777蜜臀| 欧美先锋影音| 亚洲国产精品黑人久久久| 国产精品区免费视频| 亚洲区在线播放| 激情成人在线视频| 亚洲女女女同性video| 亚洲视频一区二区在线观看| 久久久久久亚洲精品杨幂换脸| 午夜视频一区二区| 欧美日韩免费高清一区色橹橹| 美日韩精品视频| 国内精品99| 午夜精品免费视频| 午夜精品久久久久久久男人的天堂| 欧美1区3d| 亚洲电影av在线| 亚洲国产黄色片| 久久蜜桃av一区精品变态类天堂| 久久成人精品无人区| 国产精品私房写真福利视频| 一区二区三区产品免费精品久久75 | 一本色道久久综合精品竹菊 | 欧美日韩性视频在线| 亚洲第一天堂无码专区| 亚洲国产成人91精品| 久久琪琪电影院| 免费短视频成人日韩| 激情综合自拍| 久久伊人精品天天| 免费国产自线拍一欧美视频| 伊大人香蕉综合8在线视| 久久久久久网| 亚洲大片在线| 日韩视频中文| 欧美视频亚洲视频| 中日韩美女免费视频网址在线观看| 正在播放亚洲| 国产精品亚洲产品| 久久国产精品黑丝| 欧美成年人视频| 99精品视频免费观看视频| 欧美日韩一区二区在线播放| 亚洲无限av看| 欧美亚洲一区二区三区| 国产亚洲在线观看| 久久综合一区二区三区| 亚洲精品裸体| 欧美一区二区三区在线观看视频| 国产一区二区三区在线免费观看 | 欧美日韩在线另类| 午夜电影亚洲| 美国十次成人| 亚洲狼人综合| 国产目拍亚洲精品99久久精品| 欧美在线观看一区| 亚洲国产导航| 欧美一区午夜精品| 在线日韩电影| 国产精品乱子久久久久| 久久久水蜜桃av免费网站| 亚洲激情成人| 久久亚洲精选| 一区二区三区免费观看| 国产一区二区三区久久久久久久久| 久久一区二区三区四区| 亚洲一区二区三区四区在线观看| 看片网站欧美日韩| 亚洲一二三区在线| 亚洲国产精品久久久久秋霞影院| 国产精品theporn| 美女视频黄a大片欧美| 亚洲特色特黄| 91久久综合| 久久香蕉精品| 先锋影院在线亚洲| 亚洲伦理在线观看| 尤物视频一区二区| 国产精品一区二区a| 欧美激情一区在线观看| 久久九九电影| 欧美一区二区视频在线观看2020| 日韩天堂在线观看| 亚洲高清免费| 免费日韩av片| 久久久久久夜| 久久国产视频网站| 亚洲一区日韩在线| 99re热精品| 99pao成人国产永久免费视频| 一区二区在线免费观看| 国产精品综合| 国产精品乱人伦一区二区| 欧美日韩成人一区二区| 欧美精品日本| 欧美激情网友自拍| 欧美大色视频| 欧美肥婆在线| 欧美精品亚洲| 欧美日韩国产小视频| 欧美福利在线| 欧美猛交免费看| 欧美日韩aaaaa| 欧美日韩不卡| 欧美午夜不卡视频| 欧美午夜精品理论片a级按摩| 欧美日韩久久不卡| 欧美日韩性生活视频| 欧美四级在线| 国产精品视频一区二区三区| 国产精品毛片| 国产人妖伪娘一区91| 国产综合亚洲精品一区二| 精品99一区二区| 亚洲国产精品久久久久秋霞影院| 亚洲国产精品热久久| 亚洲精品字幕| 亚洲在线视频一区| 久久国产高清| 欧美高清视频在线观看| 欧美激情在线| 99在线|亚洲一区二区| 亚洲午夜91| 久久精品91| 欧美成人午夜激情在线| 欧美日韩综合视频网址| 国产日韩欧美综合一区| 伊人婷婷久久| 一区二区三区视频在线观看| 校园春色国产精品| 久久在线免费观看| 最新日韩欧美| 亚洲免费网站| 狂野欧美一区| 欧美丝袜第一区| 精品1区2区| 中文国产亚洲喷潮| 久久久国产亚洲精品| 亚洲电影自拍| 亚洲欧美一区二区在线观看| 久久天天躁夜夜躁狠狠躁2022 | 久久综合九色九九| 欧美午夜激情在线| 影音先锋国产精品| 亚洲综合色在线| 欧美激情精品久久久久久变态| 一区二区日韩精品| 玖玖在线精品| 国产美女一区| 中文久久精品| 欧美福利小视频| 午夜国产精品视频| 欧美日韩第一页| 影音先锋亚洲视频| 亚洲欧美三级在线| 91久久夜色精品国产网站| 欧美一区二区高清| 国产精品国产自产拍高清av|