Wednesday, October 7, 2009

Another day another interview

For Sapient c++

1)DEsign a system for an Online Booking System which has -
Login Credentials
Product view (can have millions of products).
Add to cart
shop the selected products
Choose the payment mode - cash/credit.

2)copy constructor
3)smart pointers
4)critical section
5)template specialization
6)why templates have implementation in header files.

But unfortunately on que 7 the call got disconnected and they didnt call me back :(
Lets see what's in store for me tomorrow.

Monday, October 5, 2009

first hindi poem that I learnt

This poem is by Ayodhya Singh Upadhayay, one of my childhood fav.

"utho laal ab aankhein kholo
paani laayi hoon, muh dholo

beeti raat kamal-dal phoole
unke ooper bhanvre jhoole

chidiya chahak uthi pedo par
behne lagi hawa ati sundar

bhor huyi sooraj ug aaya
nabh mein huyi sunhari kaaya

aasmaan mein chhaayi laali
hawa bahi sukh dene waali

nanhi-nanhi kiranein aayein
phool ha.se kaliyaan muskaayein

itana sundar samay na kho
mere pyaare ab mat so"

Thursday, September 24, 2009

Dil bole hadippa

Watched "Dil bole Hadippa" on sunday.
It was okay kind of movie...watch once and forget.

Rani was pretty convincing in role of surd boy....but as a girl she looked repetitive.
But she awed her character as Veer Singh.

Shahid Kapoor's acting can be rated as a sine wave....best to worse.
He looked like a duplicate of SRK and to add to it YashRaj Production made him wear muffler on transparent shirt....much associated with SRK.

Rest of the characters were just fillers to link the story....love story and cricket were the USP of the movie....but both the themes were lost and found couple of times in movie.

It was again one of "not on this earth movie" by the YashRaj's.
I agree love is blind and one can fall in love with anybody but not like movies.Its a dream I must say.

Terrible interview

I always wonder what interviews are meant for?
Do they test the interviewee's knowledge?
or do they check what % of interviewers know how in a tech shared by the interviewee?

I think its the second criteria most of the times.
Even I go by second when it comes to judging some one for a very specific role.

my interview today was more of a rapid fire round....it lasted just for 20 min but had 25 questions...phew.
And to add to making it terrible I made it more terrible by not replying to questions I knew the answer :(

I got so baffled...i didn't expected it to end this way. :(

here is the list of the questions that i could recall -
1) Type of stl containers
2) difference in composition, aggregation,association.
3) Predicates
4) Deadlock and Starvation
5) Raised condition
6) Diff in Conversion ctr and explicit ctr
7) diff in has_map and map
8) explain hash_map and bucketing
9) virtual inheritance, diamond problem
10) function adapters
11) fucntors
12) function objects
13) in how many ways two classes A and B be related to each other.
14) diff between vector and dqueue
15) Re-population of dqueue and its complexity.
16) types of iterators
17) how would you implement a map.
18) concept of immutability.
19) Are elements in a map ordered?
20) What type of container is a set.
21) How is a set implemented?
22) something on auto_ptr.

Would add more if I can recall them.

Till than chill out.

Thursday, September 10, 2009

rub a dub dub.....

Came across this article.....felt its worth giving a thought ....often we come across bad code.....feel like re-writing it...but sometimes its un-do-able in a given frame of time.

Rub a Dub Dub

By Joel Spolsky
January 23, 2002

One reason people are tempted to rewrite their entire code base from scratch is that the original code base wasn't designed for what it's doing. It was designed as a prototype, an experiment, a learning exercise, a way to go from zero to IPO in nine months, or a one-off demo. And now it has grown into a big mess that's fragile and impossible to add code to, and everybody's whiny, and the old programmers quit in despair and the new ones that are brought in can't make head or tail of the code so they somehow convince management to give up and start over while Microsoft takes over their business. Today let me tell you a story about what they could have done instead.

FogBUGZ started out six years ago as an experiment to teach myself ASP programming. Pretty soon it became an in-house bug tracking system. It got embellished almost daily with features that people needed until it was good enough that it no longer justified any more work.
Various friends asked me if they could use FogBUGZ at their companies. The trouble was, it had too many hardcoded things that made it a pain to run anywhere other than on the original computer where it was deployed. I had used a bunch of SQL Server stored procedures, which meant that you needed SQL Server to run FogBUGZ, which was expensive and overkill for some of the two person teams that wanted to run it. And so on. So I would tell my friends, "gosh, for $5000 in consulting fees, I'll spend a couple of days and clean up the code so you can run it on your server using Access instead of SQL Server." Generally, my friends thought this was too expensive.

After this happened a few times I had a revelation -- if I could sell the same program to, say, three people, I could charge $2000 and come out ahead. Or thirty people for $200. Software is neat like that. So in late 2000, Michael sat down, ported the code so that it worked on Access or SQL Server, pulled all the site-specific stuff out into a header file, and we started selling the thing. I didn't really expect much to come of it.

In those days, I thought, golly, there are zillions of bug tracking packages out there. Every programmer has written a dinky bug tracking package. Why would anyone buy ours? I knew one thing: programmers who start businesses often have the bad habit of thinking everybody else is a programmer just like them and wants the same stuff as them, and so they have an unhealthy tendency to start businesses that sell programming tools. That's why you see so many scrawny companies hawking source-code-generating geegaws, error catching and emailing geegaws, debugging geegaws, syntax-coloring editing tchotchkes, ftping baubles, and, ahem, bug tracking packages. All kinds of stuff that only a programmer could love. I had no intention of falling into that trap!

Of course, nothing ever works out exactly as planned. FogBUGZ was popular. Really popular. It accounts for a significant chunk of Fog Creek's revenue and sales are growing steadily. The People won't stop buying it.

So we did version 2.0. This was an attempt to add some of the most obviously needed features. While David worked on version 2.0 we honestly didn't think it was worth that much effort, so he tended to do things in what you might call an "expedient" fashion rather than, say, an "elegant" fashion. Certain, ahem, design issues in the original code were allowed to fester. There were two complete sets of nearly identical code for drawing the main bug-editing page. SQL statements were scattered throughout the HTML hither and yon, to and fro, pho and ton. Our HTML was creaky and designed for those ancient browsers that were so buggy they could crash loading about:blank.

Yeah, it worked brilliantly, we've been at zero known bugs for a while now. But inside, the code was, to use the technical term, a "big mess." Adding new features was a hemorrhoid. To add one field to the central bug table would probably require 50 modifications, and you'd still be finding places you forgot to modify long after you bought your first family carplane for those weekend trips to your beach house on Mars.
A lesser company, perhaps one run by an executive from the express-package-delivery business, might have decided to scrap the code and start over.

Did I mention that I don't believe in starting from scratch? I guess I talk about that a lot.
Anyway, instead of starting from scratch, I decided it was worth three weeks of my life to completely scrub the code. Rub a dub dub. In the spirit of refactoring, I set out a few rules for this exercise.
1. No New Features, not even small ones, would be added.
2. At any time, with any check in, the code would still work perfectly.
3. All I would do is logical transformations -- the kinds of things that are almost mechanical and which you can convince yourself immediately will not change the behavior of the code.

I went through each source file, one at a time, top to bottom, looking at code, thinking about how it could be better structured, and making simple changes. Here are some of the kinds of things I did during these three weeks:
• Changed all HTML to xhtml. For example,
became
, all attributes were quoted, all nested tags were matched up, and all pages were validated.
• Removed all formatting ( tags etc.) and put everything in a CSS style sheet.
• Removed all SQL statements from the presentation code and indeed all program logic (what the marketing types like to call "business rules"). This stuff went into classes which were not really designed -- I simply added methods lazily as I discovered a need for them. (Somewhere, someone with a big stack of 4x6 cards is sharpening their pencil to poke my eyes out. What do you mean you didn't design your classes?)
• Found repeated blocks of code and created classes, functions, or methods to eliminate the repetition. Broke up large functions into multiple smaller ones.
• Removed all remaining English language text from the main code and isolated that in a single file for easy internationalization.
• Restructured the ASP site so there is a single entry point instead of lots of different files. This makes it very easy to do things that used to be hard, for example, now we can display input error messages in the very form where the invalid input occurred, something which should be easy if you lay things out right, but I hadn't laid things out right when I was learning ASP programming way back when.
Over three weeks the code got better and better internally. To the end user, not too much changed. Some fonts are a little nicer thanks to CSS. I could have stopped at any point, because at any given time I had 100% working code (and I uploaded every checkin to our live internal FogBUGZ server to make sure). And in fact I never really had to think very hard, and I never had to design a thing, because all I was doing was simple, logical transformations. Occassionally I would encounter a weird nugget in the code. These nuggets were usually bug fixes that had been implemented over the years. Luckily I could keep the bug fix intact. In many of these cases, I realized that had I started from scratch, I would have made the same bug all over again, and may not have noticed it for months or years.
I'm basically done now. It took, as planned, three weeks. Almost every line of code is different now. Yep, I looked at every line of code, and changed most of them. The structure is completely different. All the bug-tracking functionality is completely separate from the HTML UI functionality.
Here are all the good things about my code scrubbing activity:
• It took vastly less time than a complete rewrite. Let's assume (based on how long it took us to get this far with FogBUGZ) that a complete rewrite would have taken a year. Well, that means I saved 49 weeks of work. Those 49 weeks represent knowledge in the design of the code that I preserved intact. I never had to think, "oh, I need a new line here." I just had to change
to
mindlessly and move on. I didn't have to figure out how to get multipart working for file uploads. It works. Just tidy it up a bit.
• I didn't introduce any new bugs. A couple of tiny ones, of course, probably got through. But I was never doing the types of things that cause bugs.
• I could have stopped and shipped at any time if necessary.
• The schedule was entirely predictable. After a week of this, you can calculate exactly how many lines of code you clean in an hour, and get a darn good estimate for the rest of the project. Try that, Mozilla river-drawing people.
• The code is now much more amenable to new features. We'll probably earn back the three weeks with the first new major feature we implement.
Much of the literature on refactoring is attributable to Martin Fowler, although of course the principles of code cleanups have been well known to programmers for years. An interesting new area is refactoring tools, which is just a fancy word for programs that do some of this stuff automatically. We're a long way from having all the good tools we need -- in most programming environments you can't even do a simple transformation like changing the name of a variable (and having all the references to it change automatically). But it's getting better, and if you want to start one of those scrawny companies hawking programming tool geegaws, or make a useful contribution to open source, the field is wide open.




Wednesday, September 9, 2009

couple of cups of coffee with a friend.....

The Mayonnaise Jar and Two Cups of Coffee

When things in your life seem almost too much to handle, when 24 hours in
a day are not enough, remember the mayonnaise jar and the two cups of
coffee.


=============================

A professor stood before his philosophy class and had some items in front of him. When the class began, wordlessly, he picked up a very large and empty mayonnaise jar and proceeded to fill it with golf balls.

He then asked the students if the jar was full. They agreed that it was.

The professor then picked up a box of pebbles and poured them into the jar. He shook the jar lightly. The
pebbles rolled into the open areas between the golf balls. He then asked the students again if the jar was full. They agreed it was.

The professor next picked up a box of sand and poured it into the jar. Of course, the sand filled up everything else. He asked once more if the jar was full. The students responded with a unanimous "yes".

The professor then produced two cups of coffee from under the table and poured the entire contents into the jar, effectively filling the empty space between the sand. The students laughed.

"Now," said the professor, as the laughter subsided, " I want you to recognize that this jar represents your life.

The golf balls are the important things in life. Your God, your family, your children, your health, your friends, and your favorite passions: things that if everything else was lost and only they remained, your life would still be full.

The pebbles are the other things that matter like your job, your house, and your car.

The sand is everything else: the small stuff.

"If you put the sand into the jar first," he continued, "there is no room for the pebbles or the golf balls. The same goes for life. If you spend all your time and energy on the small stuff, you will never have room for the things that are important to you. Pay attention to the things that are critical to your happiness.

Play with your children. Take time to get medical checkups. Take your partner out to dinner. Play another 18. There will always be time to clean house and fix the disposal.

Take care of the golf balls first; the things that really matter. Set your priorities. The rest is just sand.

One of the students raised her hand and inquired what the coffee
represented. The professor smiled. "I'm glad you asked. It just goes to show you that no matter how full your life may seem, there's always room for a couple of cups of coffee with a friend."

=================

River crossing puzzle

There are 3 couples who want to cross the river.

Raja-wife A - P
Wajir-wife B - Q
Sainik-wife C - R

Rule s
1. There is a boat of capacity 2.
2. Saink and his wife cant travel with other fours since they are of low category
3. If on any side there is a single man with either 2 or 3 wives, he will run away with them .For the sake of simplicity I assumed the characters as below and in same order –

Males - A B C

Females -P Q R

A

B

C

|




P

Q

R

|







|




A

B


|



C

P

Q


|



R




|




A

B

C

|




P

Q


|



R




|




A

B

C

|







|

P

Q

R




|




A

B

C

|






R

|

P

Q





|






C

|

A

B




R

|

P

Q





|





B

C

|

A




Q

R

|

P






|





B


|

A


C


Q


|

P


R




|




A

B


|



C

P

Q


|



R




|







|

A

B

C

P

Q


|



R




|







|

A

B

C

P

Q

R

|







|

A

B

C




|

P

Q





|






C

|

A

B




R

|

P

Q





|







|

A

B

C




|

P

Q

R