Skip to main content

Problem 19 Project Euler solution with python

Counting Sundays

You are given the following information, but you may prefer to do some research for yourself.
  • 1 Jan 1900 was a Monday.
  • Thirty days has September,
    April, June and November.
    All the rest have thirty-one,
    Saving February alone,
    Which has twenty-eight, rain or shine.
    And on leap years, twenty-nine.
  • A leap year occurs on any year evenly divisible by 4, but not on a century unless it is divisible by 400.
How many Sundays fell on the first of the month during the twentieth century (1 Jan 1901 to 31 Dec 2000)?

To solve this problem I have used inbuilt calendar module.
I will first explain some code before we will solve the problem.

Calendar module is a inbuilt module in python with which you can perform all the calculations related to  days, year, months etc.
In calendar module days(days of week) are represented in number format.
They are as follows:
0 - Monday
1 - Tuesday
2 - Wednesday
3 - Thursday
4 - Friday
5 - Saturday
6 - Sunday

This module by default assumes that the week starts with Monday.To use calendar module, you first have to import it.

>>> import calendar
>>> 
To change the start of week from Monday to Sunday we do as follows:

>>> calendar.setfirstweekday(6)#6-Sunday
>>> 
To check the first week day:

>>> calendar.firstweekday()
6
>>> 
To print calendar for a year:

>>> calendar.prcal(2016)
The output will be as follows:
2016 calendar generated using python
Printing calender for a specified month:
>>> calendar.prmonth(2016,4)
Output will look something like this:
April 2016 Calendar generated using python
April 2016 Calendar generated using python
Till now we have seen the calenders in a neat human readable format. But for our computation these are not useful, we will have to use matrices. To generate a months calender in a matrix form then(For April 2016):

>>> calendar.monthcalendar(2016,4)
Matrix generated by above code will be as follows:
[[0, 0, 0, 0, 0, 1, 2], [3, 4, 5, 6, 7, 8, 9], [10, 11, 12, 13, 14, 15, 16], [17, 18, 19, 20, 21, 22, 23], [24, 25, 26, 27, 28, 29, 30]]
Consider the first list in the list generated above. If we write the above in a human readable calendar format then it will look something like this:
April
Su Mo Tu We Th Fr Sa
0 0 0 0 0 1 2
As you have seen, if in the first list the first number(index 0) is 1 then the month has started with Sunday.
This is the concept behind our program. This may look complicated but is very simple. Try to understand it. If you haven't understood it then read this post again or you can see the official documentation. 

Program 

Program using the above concept is as follows:
It will be very simple once you have understood the above concept or algorithm whatever you call it.
You can download the above program from Github Gist pep19.py.

Output

Summary

I think this problem is easy if you knew calendar module. Once I understood the calender module, it just took me a few minutes to solve this problem.

I have not explained any code because the code is well commented and also it is easy once you understand the concept behind it. If you haven't understood anything comment in the comment box below and I will be glad to help you.

Please don't hesitate to comment if you have found any typo or have a different/better code.

You can also contact me .

Thank you. Have a nice day.

Popular posts from this blog

Problem 60 Project Euler Solution with python

Prime pair sets The primes 3, 7, 109, and 673, are quite remarkable. By taking any two primes and concatenating them in any order the result will always be prime. For example, taking 7 and 109, both 7109 and 1097 are prime. The sum of these four primes, 792, represents the lowest sum for a set of four primes with this property. Find the lowest sum for a set of five primes for which any two primes concatenate to produce another prime. This problem is j u st a brute force problem. If you have come here because you don't know the limit upto which you will h ave to gener ate the prime numbers t hen go ahe ad and t r y with 10,000 . When I first start ed solving the problem I chose 1 million(beca use most of the problem s on project E uler have this limit ), but it took very long for the computer to fin d the solution. After searching on the internet then I found many people choosing 10, 000 so I have changed my in put f rom 1 million to 10000 and the output was f ast. He...

Add/Embed SVG to Blogger website

In this post I will tell you my method(trick) of adding SVG images in a blogger website or blog. Before starting , the first thin g I am assu m ing is that you are aware of SVG if you are here. If not please see S calable V ec tor G raphics Recently when I tried to embed a SVG image for a post on pygal, I tried uploading the SVG file and blogger Image uploader came up with an error, because of which I had to find some other way.  SVG File upload Error in Blogger  I started sea rc hing Google " Embed SVG in Blogger " . I found blogorrhea , w h ich gave some i nformatio n on add ing SVG directly as a markup , which worked , but I faced another problem using this . Also th is guy has used lot of Javascript which was confusin g for me, being new to using SVG.   So I first t houg ht of learning on h ow to embed SVG in HTML and t his on e worked out. Actually we can embed SVG in HTML i n following ways: Using Object tag Using Iframe tag Using embed...

Making a quiz web app with python and flask

Edit : When you are creating a web app with h tml templates, then y ou will have to sa ve the html file in templates folder in the Current Wor ki ng Directory( CWD). If you save the file in the C W D directl y you will get a TemplateNotFound error. Thank you Udhay for pointing it out.   In this post we will create a quiz website using python . I will be using the flask framework . After reading this tutorial you will learn form submission , flask templates , python code in flask templates , shuffling the questions and options with the random module and few others.  Please note that this tutorial is not big as it seems to be. Some of the code has been rewritten to maintain consistency and also font size is somewhat big so that your eyes won't get stressed reading this tutorial. Also the content has not occupied the full width of the page. In this tutorial I am assuming that you are having a very basic understanding of the flask framework . Please refer the documenta...