跪求一个300多行的C++程序 ?

只要是能够运行的程序就好300多行就行额我能给的最高分可以都给你... 只要是能够运行的 程序就好 300多行就行 额 我能给的最高分可以都给你 展开
 我来答
热心又舒爽丶东风3585
2014-07-11 · TA获得超过101个赞
知道答主
回答量:115
采纳率:0%
帮助的人:113万
展开全部
#include <iostream> using namespace std; class Date { private: int year; int month; int day; friend void inputDate(Date& d); friend int goday(Date& d); friend void frontDate(Date& d); friend void backDate(Date& d); friend int distanceDate(Date& d1,Date& d2); public: Date(int y=0,int m=0,int d=0):year(y),month(m),day(d) {} void print() { cout<<year<<"\t"<<month<<"\t"<<day<<"\t"; } }; void inputDate(Date& d) { cout<<"Please input year:"<<"\t"; cin>>d.year; cout<<"Please input month:"<<"\t"; cin>>d.month; cout<<"Please input day:"<<"\t"; cin>>d.day; } int goday(Date& d) { if((d.year%4==0&&d.year%100!=0)||d.year%400==0) { if(d.month<=2) return (d.month-1)*31+d.day; else if(d.month>2&&d.month<=7) { if(d.month%2==1) return 60+d.day+61*(d.month-3)/2; else if(d.month%2==0) return 60+d.day+61*(d.month-4)/2+31; } else if(d.month>7) { if(d.month%2==0) return 213+d.day+61*(d.month-8)/2; else if(d.month%2==1) return 213+d.day+61*(d.month-9)/2+31; } } else { if(d.month<=2) return (d.month-1)*31+d.day; else if(d.month>2&&d.month<=7) { if(d.month%2==1) return 59+d.day+61*(d.month-3)/2; else if(d.month%2==0) return 59+d.day+61*(d.month-4)/2+31; } else if(d.month>7) { if(d.month%2==0) return 212+d.day+61*(d.month-8)/2; else if(d.month%2==1) return 212+d.day+61*(d.month-9)/2+31; } } } void frontDate(Date& d) { if(d.month==1&&d.day==1) { --d.year; d.month=12; d.day=31; } else if(d.month==2&&d.day==1) { d.month=1; d.day=31; } else if(d.month==3&&d.day==1) { if(d.year%4==0&&d.year%100!=0||d.year%400==0) { d.month=2; d.day=29; } else { d.month=2; d.day=28; } } else if(d.month>3&&d.month<=7&&d.day==1) { if(d.month%2==0) { --d.month; d.day=31; } else { --d.month; d.day=30; } } else if(d.month==8&&d.day==1) { --d.month; d.day=31; } else if(d.month>8&&d.day==1) { if(d.month%2==0) { --d.month; d.day=30; } else { --d.month; d.day=31; } } else if(d.day!=1) { --d.day; } cout<<d.year<<"\t"<<d.month<<"\t"<<d.day<<"\t"; } void backDate(Date& d) { if(d.month==12) { if(d.day==31) { ++d.year; d.month=1; d.day=1; } else { ++d.day; } } else if(d.month==1) { if(d.day==31) { ++d.year; d.month=2; d.day=1; } else ++d.day; } else if(d.month=2) { if(d.year%4==0&&d.year%100!=0||d.year%400==0) { if(d.day==29) { d.day=1; d.month=3; } else { ++d.day; } } else { if(d.day==28) { d.day=1; d.month=3; } else { --d.day; } } } else if(d.month!=2&&d.month!=12) { if(d.month<=7) { if(d.month%2==1) { if(d.day==31) { d.day=1; ++d.month; } else { ++d.day; } } else { if(d.day==30) { d.day=1; ++d.month; } else { ++d.day; } } } else if(d.month>7) { if(d.month%2==0) { if(d.day==31) { d.day=1; ++d.month; } else { ++d.day; } } else { if(d.day==30) { d.day=1; ++d.month; } else { ++d.day; } } } } cout<<d.year<<"\t"<<d.month<<"\t"<<d.day<<"\t"; } int distanceDate(Date& d1,Date& d2) { int m,n; m=goday(d1); n=goday(d2); if((d2.year-d1.year)>=0) { if((d2.year-d1.year)%4==0) return 1461*(d2.year-d1.year)/4+n-m; if((d2.year-d1.year)%4==1) { if(d1.year%4==0&&d1.year%100!=0||d1.year%400==0) return 1461*(d2.year-d1.year-1)/4+n-m+366; else return 1461*(d2.year-d1.year-1)/4+n-m+365; } if((d2.year-d1.year)%4==2) { if((d1.year%4==0&&d1.year%100!=0||d1.year%400==0)||((d1.year+1)%4==0&&(d1.year+1)%100!=0||(d1.year+1)%400==0)) return 1461*(d2.year-d1.year-2)/4+n-m+365+366; else return 1461*(d2.year-d1.year-2)/4+n-m+365+365; } if((d2.year-d1.year)%4==3) { if((d1.year%4==0&&d1.year%100!=0||d1.year%400==0)||((d1.year+1)%4==0&&(d1.year+1)%100!=0||(d1.year+1)%400==0)||((d1.year+2)%4==0&&(d1.year+2)%100!=0||(d1.year+2)%400==0)) return 1461*(d2.year-d1.year-3)/4+n-m+366+365+365; else return 1461*(d2.year-d1.year-3)/4+n-m+365+365+365; } } else { if((d1.year-d2.year)%4==0) return 1461*(d1.year-d2.year)/4+m-n; if((d1.year-d2.year)%4==1) { if(d2.year%4==0&&d2.year%100!=0||d2.year%400==0) return 1461*(d1.year-d2.year-1)/4+m-n+366; else return 1461*(d1.year-d2.year-1)/4+m-n+365; } if((d1.year-d2.year)%4==2) { if((d2.year%4==0&&d2.year%100!=0||d2.year%400==0)||((d2.year+1)%4==0&&(d2.year+1)%100!=0||(d2.year+1)%400==0)) return 1461*(d1.year-d2.year-2)/4+m-n+365+366; else return 1461*(d1.year-d2.year-2)/4+m-n+365+365; } if((d1.year-d2.year)%4==3) { if((d2.year%4==0&&d2.year%100!=0||d2.year%400==0)||((d2.year+1)%4==0&&(d2.year+1)%100!=0||(d2.year+1)%400==0)||((d2.year+2)%4==0&&(d2.year+2)%100!=0||(d2.year+2)%400==0)) return 1461*(d1.year-d2.year-3)/4+m-n+366+365+365; else return 1461*(d1.year-d2.year-3)/4+m-n+365+365+365; } } } int main() { Date d1,d2,d; int m; inputDate(d1); inputDate(d2); d1.print(); d2.print(); m=distanceDate(d1,d2); cout<<"d2 distance d1 is:"<<"\t"; cout<<m<<endl; cout<<"distance from the year's first day is:"<<"\t"; cout<<goday(d1)<<endl; cout<<"The front of date d1 is:"<<"\t"; frontDate(d1); cout<<"The date d1 is:"<<"\t"; backDate(d1); cout<<"The back of date d1 is:"<<"\t"; backDate(d1); }
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式