Solved

Sorting Dates

Posted on 2003-10-30
4
140 Views
Last Modified: 2010-04-17
I have an array full of birthdays but am having trouble using srtcmp to sort them.
0
Comment
Question by:Toy_Toy
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
4 Comments
 
LVL 23

Accepted Solution

by:
brettmjohnson earned 75 total points
ID: 9655414
You can use strcmp to sort on dates if the dates are of the form YYYYMMDD .
It still works if there is delimiters between year month and day  2003/10/29 .

You could attempt to a triple-sort on year, month, and day.  However, I would
simply convert the dates to a numerical time - either time_t or simply number
of days since some baseline.

/* returns number of days since year 0 for year.
 * understands leapyears, but ignores julian
 * calendar changes.  this is dumb and simplistic.
 */
static int numdays (int year, int month, int day)
{
  static int mdays[] = { 0, 0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365 };
  int days;

  /* as a convenience, assume a two digit year is modern */
  if (year < 100)
    year += (year < 10)? 2000 : 1900;

  if ((month < 1) || (month > 12))
    month = 1;
  if ((day < 1) || (day > 31))
    day = 1;

  days = year*365 + year/4 - (year/100 - year/400);
  days += mdays[month];
  days += day;

  /* add a day if current year is leap year */
  if ((month > 2) && !(year % 4) && (year %100) && !(year % 400))
    days++;

  return days;
}
0

Featured Post

The Ultimate Checklist to Optimize Your Website

Websites are getting bigger and complicated by the day. Video, images, custom fonts are all great for showcasing your product/service. But the price to pay in terms of reduced page load times and ultimately, decreased sales, can lead to some difficult decisions about what to cut.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Entering a date in Microsoft Access can be tricky. A typo can cause month and day to be shuffled, entering the day only causes an error, as does entering, say, day 31 in June. This article shows how an inputmask supported by code can help the user a…
Whether you’re a college noob or a soon-to-be pro, these tips are sure to help you in your journey to becoming a programming ninja and stand out from the crowd.
With the power of JIRA, there's an unlimited number of ways you can customize it, use it and benefit from it. With that in mind, there's bound to be things that I wasn't able to cover in this course. With this summary we'll look at some places to go…
Simple Linear Regression

705 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question