Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 144
  • Last Modified:

Sorting Dates

I have an array full of birthdays but am having trouble using srtcmp to sort them.
0
Toy_Toy
Asked:
Toy_Toy
1 Solution
 
brettmjohnsonCommented:
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

VIDEO: THE CONCERTO CLOUD FOR HEALTHCARE

Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now