国产女人18毛片水真多18精品, 一区二区三区中文字-亚洲精品女国产, 欧美熟妇老熟妇88888久久久久, 一级毛片免费观看亚洲欧美国产精品,大波霸美女视频,日韩欧美激情V影院,熟女人伦21p,亚洲精品女国产,国产 乱子伦 在线

判斷兩個(gè)日期之差的小程序

時(shí)間:2025-09-21 17:20:34 C語言

判斷兩個(gè)日期之差的小程序

  引導(dǎo)語:我們利用c語言可以編寫出許多有趣的小程序,以下是百分網(wǎng)小編分享給大家的判斷兩個(gè)日期之差的小程序,歡迎閱讀!

  1.普通的寫法

  #include

  int leapyear(int year)

  {

  if((year%4==0 && year%100!=0) || year%400==0)

  return 1;

  else

  return 0;

  }

  int days(int *day1, int *day2)

  {

  int i=0;

  int *tmp;

  int diff = 0;

  const int month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};

  if(day1[0] == day2[0])

  {

  if(day1[1] == day2[1])

  {

  diff = day1[2] - day2[2];

  diff = (diff < 0)?(-diff):diff;

  }

  else

  {

  if(day1[1] < day2[1]) /pic/p>

  {

  tmp = day1; /pic/p>

  day1 = day2;

  day2 = tmp;

  }

  for(i=day2[1]+1; i

  {

  diff += month[i];

  }

  diff += month[day2[1]] - day2[2] + day1[2];

  if(day2[1] <= 2 && day1[1] >2)

  if(leapyear(day2[0]))

  diff++;

  }

  }

  else

  {

  if(day1[0] < day2[0])

  {

  tmp = day1;

  day1 = day2;

  day2 = tmp;

  }

  for(i=day2[0]+1; i

  {

  if(leapyear(i))

  diff += 366;

  else

  diff += 365;

  }

  for(i=day2[1]+1; i<=12; i++) /pic/p>

  {

  diff += month[i];

  }

  diff += (month[day2[1]] - day2[2]);

  if(day2[1] <= 2)

  if(leapyear(day2[0]))

  diff++;

  for(i=1; i

  {

  diff += month[i];

  }

  diff += day1[2];

  if(day1[1] > 2)

  if(leapyear(day1[0]))

  diff++;

  }

  return diff;

  }

  int main()

  {

  int day1[3], day2[3];

  int day = 0;

  printf("輸入日期:");

  scanf("%d-%d-%d",&day1[0], &day1[1], &day1[2]);

  printf("輸入另一個(gè)日期:");

  scanf("%d-%d-%d",&day2[0], &day2[1], &day2[2]);

  day = days(day1, day2);

  printf("兩個(gè)日期之間共有%d天。n",day);

  return 0;

  }

  2.利用結(jié)構(gòu)體,代碼更整潔一些

  #include

  typedef struct date

  {

  int year;

  int month;

  int day;

  }DATE;

  int leapyear(int year)

  {

  if((year%4==0 && year%100!=0) || year%400==0)

  return 1;

  else

  return 0;

  }

  int compare(DATE *d1, DATE *d2) /pic/p>

  {

  DATE *tmp;

  if(d1->year == d2->year) /pic/p>

  {

  if(d1->month > d2->month) /pic/p>

  {

  tmp = d1;

  d1 = d2;

  d2 = d1;

  }

  else if(d1->month == d2->month) /pic/p>

  {

  if(d1->day > d2->day)

  {

  tmp = d1;

  d1 = d2;

  d2 = d1;

  }

  }

  }

  else if(d1->year > d2->year)

  {

  tmp = d1;

  d1 = d2;

  d2 = tmp;

  }

  return 0;

  }

  int diff(DATE *date1, DATE *date2)

  {

  int i;

  int diff = 0;

  const int month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};

  if(date1->year == date2->year)

  {

  if(date1->month == date2->month)

  {

  diff = date2->day - date1->day;

  }

  else

  {

  for(i=date1->month+1; imonth; i++)

  {

  diff += month[i];

  }

  diff += month[date1->month] - date1->day + date2->day;

  if(leapyear(date1->year))

  if(date1->month <=2 && date2->month >2)

  diff++;

  }

  }

  else

  {

  for(i=date1->year+1; iyear; i++)

  {

  if(leapyear(i))

  diff += 366;

  else

  diff += 365;

  }

  for(i=date1->month+1; i<=12; i++) /pic/p>

  {

  diff += month[i];

  }

  diff += month[date1->month] - date1->day;

  if(date1->month <= 2)

  if(leapyear(date1->year))

  diff++;

  for(i=1; imonth; i++) /pic/p>

  {

  diff += month[i];

  }

  diff += date2->day;

  if(date1->month > 2)

  if(leapyear(date2->year))

  diff++;

  }

  return diff;

  }

  int main()

  {

  int days = 0;

  DATE day1, day2;

  DATE *date1, *date2;

  date1 = &day1;

  date2 = &day2;

  printf("輸入日期:");

  scanf("%d-%d-%d",&(date1->year), &(date1->month), &(date1->day));

  printf("輸入另一個(gè)日期:");

  scanf("%d-%d-%d",&date2->year, &date2->month, &date2->day);

  compare(date1, date2);

  days = diff(date1, date2);

  printf("兩個(gè)日期之間共有%d天。n",days);

  return 0;

  }

【判斷兩個(gè)日期之差的小程序】相關(guān)文章:

C語言判斷兩個(gè)日期只差的方法02-22

轉(zhuǎn)換中文日期的PHP程序12-14

分享轉(zhuǎn)換中文日期的PHP程序08-08

如何判斷C語言小程序三角型類型03-09

用php計(jì)算兩個(gè)日期相差天數(shù)03-04

如何判斷三角形類型的c語言小程序10-05

c語言10個(gè)經(jīng)典小程序03-19

10個(gè)經(jīng)典的C語言小程序08-19

10個(gè)C語言經(jīng)典小程序02-28