java运算,今天是星期二,100天以后是星期几

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java运算,今天是星期二,100天以后是星期几相关的知识,希望对你有一定的参考价值。

import java.util.Calendar;

public class TestCalendar

  public static void main(String[] args)
  Calendar c = Calendar.getInstance();
  System.out.println("今天是"+transWeek2Chn(c.get(Calendar.DAY_OF_WEEK)));
  c.add(Calendar.DATE, 100);
  System.out.println("100天后是"+transWeek2Chn(c.get(Calendar.DAY_OF_WEEK)));
  

  /**星期日期转化<br/>
  * 西方通常将周日视为每周的第一天;<br/>
  * 国人习惯将周一视为每周的第一天;<br/>
  * 将星期日期转化为国人的习惯显示
  * @param w
  * @return
  */
  public static String transWeek2Chn(int w)
  switch (w)
  case 1:
   return "星期日";
  case 2:
   return "星期一";
  case 3:
   return "星期二";
  case 4:
   return "星期三";
  case 5:
   return "星期四";
  case 6:
   return "星期五";
  case 7:
   return "星期六";
  default:
   return "";


参考技术A 您好,提问者:
public class DateDemo
public static void main(String[] args)
java.util.Calendar cd = java.util.Calendar.getInstance();
cd.add(java.util.Calendar.DAY_OF_MONTH, 100);
System.out.println(new java.text.SimpleDateFormat("E").format(cd.getTime()));


//输出结果:星期三
参考技术B 100/7取余结果加2 参考技术C 说的在清楚点

C++,,,课堂作业求助,,,编写一个程序,,计算自己的生日距离今天多少天,,是星期几

编写一个程序,,计算自己的生日距离今天多少天,,是星期几

参考技术A #include <time.h>
tm t;
_getsystime(&t);

// struct tm
// int tm_sec; /* seconds after the minute - [0,59] */
// int tm_min; /* minutes after the hour - [0,59] */
// int tm_hour; /* hours since midnight - [0,23] */
// int tm_mday; /* day of the month - [1,31] */
// int tm_mon; /* months since January - [0,11] */
// int tm_year; /* years since 1900 */
// int tm_wday; /* days since Sunday - [0,6] */
// int tm_yday; /* days since January 1 - [0,365] */
// int tm_isdst; /* daylight savings time flag */
// ;
参考技术B #include"iostream.h"
void main()


bool m;
int date[12]=31,28,31,30,31,30,31,31,30,31,30,31;
int year1,mon1,day1;
int year,mon,day,weekend;
int i,total=0;
loop:
cout<<"输入你的出生日期(年月日):";
cin>>year1>>mon1>>day1;
cout<<"输入今天的日期:";
cin>>year>>mon>>day;
cout<<"今天是星期几:";
cin>>weekend;
if(year%4==0)
if(year%100!=0||year%400==0) date[1]=29;m=true;
//判断是否是闰年。
try

if(year<year1) throw year;
if(mon<1||mon>12||mon1<1||mon1>12) throw mon;
if(day1>date[mon1-1]||day>date[mon-1]) throw day;

catch(int)
cout<<"数据Error!"<<endl;
cout<<"**********************"<<endl;
goto loop;

//检验输入数据是否正确。
if(mon<=mon1)
for(i=mon;i<mon1;i++) total=total+date[i];
total=total+day1-day;
if(total<0)
if(m==true) total=366+total;
else total=365+total;

else
for(i=mon1;i<mon;i++) total=total+date[i];
total=total+day-day1;
if(m==true) total=366-total;
else total=365-total;
cout<<"你的生日距今还有:"<<total<<"天"<<endl;
weekend=(weekend+total%7)%7;
if(weekend==0) cout<<"星期天"<<endl;
else
cout<<"星期:"<<weekend<<endl;
参考技术C /*
date.h
*/

/*
定义和实现日期类
Microsoft Visual C++ .NET编译通过
*/
#include "time.h"
#include "iostream"
using namespace std;

class date
public:
date();
date(int year,int month,int day);
int ydays() const;
int get_day() const;
int get_month() const;
int get_year() const;
int get_week() const;
void set_day(int day);
void set_month(int month);
void set_year(int year);
static bool isLeapYear(int year);
static unsigned long int count_days(const date& begin,const date& end);
private:
int m_year;
int m_month;
int m_day;
;
date::date()

//默认构造函数,用当前时间初始化
time_t temp;
time(&temp);
tm *_time=localtime(&temp);
m_year=_time->tm_year+1900;
m_month=_time->tm_mon;
m_day=_time->tm_mday;

date::date(int year,int month,int day):m_year(year),m_month(month-1),m_day(day)


int date::get_day() const

return m_day;

int date::get_month() const

return m_month;

int date::get_year() const

return m_year;


void date::set_day(int day)

m_day=day;

void date::set_month(int month)

m_month=month;

void date::set_year(int year)

m_year=year;

int date::ydays() const

//计算从1月1号到当前日期的天数
int total=m_day;
int mt[]=31,28+isLeapYear(m_year),31,30,31,30,31,31,30,31,30,31;
for (int i=0;i<m_month;i++)

total+=mt[i];

return total;

bool date::isLeapYear(int year)

//判断闰年
if((year % 400 == 0)||(year % 4 == 0)&&(year % 100 != 0))

return true;

return false;

unsigned long int date::count_days(const date& begin,const date& end)//to-do

//计算两个日期间隔的时间
int total=0;
if (begin.get_year()==end.get_year())

total+=(end.ydays()-begin.ydays());

else

total+=(365-begin.ydays()+end.ydays()+isLeapYear(begin.get_year()));
for (int i=begin.get_year()+1;i<end.get_year();i++)

total+=(365+isLeapYear(i));


return total;

///////////////////////////////////////////////////////////////
/*
test.cpp
*/

/*
调用date类实现了题目要求的操作
星期的计算以公元1年1月1日星期一为参照点
Microsoft Visual C++ .NET编译通过
*/
#include "stdafx.h"
#include "iostream"
#include "date.h"
using namespace std;

/*
http://zhidao.baidu.com/question/42587847.html
计算自己的生日距离今天多少天,,是星期几
*/

int _tmain(int argc, _TCHAR* argv[])

void print(const date& t);//日期的输出
int week(const date& t);//星期的计算
date now;//当前日期

//在此换成个人生日
date birthday(2007,12,22);

//输出
cout<<"从";
print(birthday);
cout<<"[星期"<<week(birthday)<<"]\n";
cout<<"到";
print(now);
cout<<"[星期"<<week(now)<<"]\n";
cout<<"一共是";
cout<<date::count_days(birthday,now)<<"天.\n";
return 0;

void print(const date& t)

cout<<t.get_year()<<"年"<<t.get_month()+1<<"月"<<t.get_day()<<"日";

int week(const date& t)

//以公元1月1日(星期1)为参照点
unsigned long int days=0;
int week=0;
date ref(1,1,1);
days=date::count_days(ref,t);
week=days%7+1;
return week;
本回答被提问者采纳
参考技术D 这个好像直接就有个api函数的,

以上是关于java运算,今天是星期二,100天以后是星期几的主要内容,如果未能解决你的问题,请参考以下文章

用C语言输入年月日,输出距今天还有多少天,星期几,是不是是公历节日

c语言判断这一天属于这一年的第几个星期。的小疑问

如果今天是星期一,则在 Azure 数据工厂中添加动态内容以传递参数以获取最近 03 天

计算某一天是星期几?—— 蔡勒(Zeller)公式

javascript 中怎么获取今天是当月的第几个星期

linux shell 怎么得到上星期天的日期