What do architects, artists, authors, and athletes have in common that programmers lack? If you said they all start with the letter A, you are correct! I would like to submit another thing most of these people do: admire and learn from the masterful results of the best.
As programmers we have volumes we can learn from the giants: Linus, Dennis, And Others.
Well in that vein, I made up my mind to peruse the script of another famous programmer. Years ago I was watching a Ludum Dare stream from a guy named nizzotch and thought to myself, "self, this guy is good, he should be famous! The world is not just.." A year or so later notch thrust himself violently onto the unsuspecting world with his mega successful game minecraft.
Metagun's source is a rich deposit of history and learning. You may want to check out some projects that weren't created in 48 hours as well!
ID's Projects
NetHack
Gish Lugaru
Open Source Projects
And here are some great creations that aren't games!
Linux Kernel
Nagios
Virtual Box
Go, Learn, Be Happy.
Ultifinitus
mov eax, ultifinitus cmp eax, everyone jg var mov bl, 00000001B var: mov bl, 0
Thursday, February 6, 2014
Friday, April 15, 2011
String Permutation.
I Have Been Working On This Forever
First: String permutation is finding every possible combination of the letters in a string. For example:
-----------
string = "abc"
permutations:
abc
acb
bac
bca
cab
cba
----------
I have had a ton of fun with this, essentially I knew there were solutions available, and I'm sure there are a lot of better solutions as well. However, here's what I came up with.
Step 1. Write a function to swap two characters.
Step 2. Write a recursive function to return all permutations of a given string. It will call itself (minus the) first letter.
-1-
-2-
I was lying in bed, attempting to sleep, and *pop* I knew how to do it! My solution is essentially this. Take the previous call in the recursive loop (down to one letter which shall return itself) append the current letter to each, then add yourself to a vector after switching the current letter with every single letter in each permutation. beautiful
First: String permutation is finding every possible combination of the letters in a string. For example:
-----------
string = "abc"
permutations:
abc
acb
bac
bca
cab
cba
----------
I have had a ton of fun with this, essentially I knew there were solutions available, and I'm sure there are a lot of better solutions as well. However, here's what I came up with.
Step 1. Write a function to swap two characters.
Step 2. Write a recursive function to return all permutations of a given string. It will call itself (minus the) first letter.
-1-
string getstringwithswappedchars(int first, int second, string toswap){ char buf = toswap[first]; toswap[first] = toswap[second]; toswap[second] = buf; return toswap; }
-2-
I was lying in bed, attempting to sleep, and *pop* I knew how to do it! My solution is essentially this. Take the previous call in the recursive loop (down to one letter which shall return itself) append the current letter to each, then add yourself to a vector after switching the current letter with every single letter in each permutation. beautiful
vector <string> permute(string toperm){ cout << "\npermuting " << toperm; vectortoret; if (toperm.size() <= 1){ toret.push_back(toperm); return toret; } vector tvect = permute(toperm.substr(1,toperm.size()-1)); for (int b = 0; b < tvect.size(); b++){ for (int a = 0; a < toperm.size(); a++){ toret.push_back(getstringwithswappedchars(0,a,toperm[0] + tvect[b])); } } return toret; }
Thursday, April 14, 2011
First Post <(0.o)>
*** Well it's about time!!! *** (I can hear some of you yelling at your computer)
In this blog I hope to entertain you (oh great, another programmer without a sense of humor), and perhaps teach you some stuff. So lets start off with a little of both!
----------------------
A Joke:
A man died and went to heaven. As he stood in front of St. Peter at the Pearly Gates, he saw a huge wall of clocks behind him. He asked, 'What are all those clocks?'
St. Peter answered, 'Those are Lie-Clocks. Everyone on Earth has a Lie-Clock. Every time you lie the hands on your clock will move.'
'Oh,' said the man, 'whose clock is that?'
'That's Mother Teresa's. The hands have never moved, indicating that she never told a lie.'
'Incredible,' said the man. 'And whose clock is that one?'
St. Peter responded, 'That's Abraham Lincoln's clock. The hands have moved twice, telling us that Abe told only two lies in his entire life.'
'So where's George Bush's clock?' asked the man.
'Bush's clock is in Jesus' office. He's using it as a ceiling fan.
---------------------
And a little bit of programming:
As it's my first post, a small prank program! Don't expect much trivial stuff like this, I'll try to post useful things that I learn, and updates on projects, and keep stuff like this to a minimum.
A note: the previous program is extremely annoying, and I wouldn't recommend using this on any computer. However it does demonstrate some useful functionality!
Here's the gist of simulating keypresses in windows- you have a couple options, the most predominate the keybd_event() function above. There are also other references you may wish to view:
Software Simulation Intro && MSDN
You also have the option of writing a driver to create the input, here are some possibly relevant links:
-WikiBook intro
-c++ vs asm
-osronine
-MSDN Drivers
-Driver Interrupts
In this blog I hope to entertain you (oh great, another programmer without a sense of humor), and perhaps teach you some stuff. So lets start off with a little of both!
----------------------
A Joke:
A man died and went to heaven. As he stood in front of St. Peter at the Pearly Gates, he saw a huge wall of clocks behind him. He asked, 'What are all those clocks?'
St. Peter answered, 'Those are Lie-Clocks. Everyone on Earth has a Lie-Clock. Every time you lie the hands on your clock will move.'
'Oh,' said the man, 'whose clock is that?'
'That's Mother Teresa's. The hands have never moved, indicating that she never told a lie.'
'Incredible,' said the man. 'And whose clock is that one?'
St. Peter responded, 'That's Abraham Lincoln's clock. The hands have moved twice, telling us that Abe told only two lies in his entire life.'
'So where's George Bush's clock?' asked the man.
'Bush's clock is in Jesus' office. He's using it as a ceiling fan.
---------------------
And a little bit of programming:
As it's my first post, a small prank program! Don't expect much trivial stuff like this, I'll try to post useful things that I learn, and updates on projects, and keep stuff like this to a minimum.
#include < windows.h > using namespace std; void setKey(int key,bool down, bool scan = true){ BYTE keyState[256]; if (scan){ GetKeyboardState((LPBYTE)&keyState); if( down && !(keyState[key] & 1)){ keybd_event( VkKeyScan(key), /*MapVirtualKeyA(key,2)*/0, KEYEVENTF_EXTENDEDKEY | 0, 0 ); } else if ( !down && (keyState[key] & 1)){ // Simulate a key release keybd_event( VkKeyScanA( key), /*MapVirtualKeyA(key,2)*/0, KEYEVENTF_EXTENDEDKEY | KEYEVENTF_KEYUP, 0); } } else{ GetKeyboardState((LPBYTE)&keyState); if( down && !(keyState[key] & 1)){ keybd_event( key, /*MapVirtualKeyA(key,2)*/0, KEYEVENTF_EXTENDEDKEY | 0, 0 ); } else if ( !down && (keyState[key] & 1)){ // Simulate a key release keybd_event( key, /*MapVirtualKeyA(key,2)*/0, KEYEVENTF_EXTENDEDKEY | KEYEVENTF_KEYUP, 0); } } } int main(){ int time = GetTickCount(); int count = 0; while (count < 2){ for (int temp = 0; temp < 256; temp++){ setKey(temp,true,false); setKey(temp,false,false); Sleep(10); } if (GetTickCount() - time >= 10000){ count++; time = GetTickCount(); } } }
A note: the previous program is extremely annoying, and I wouldn't recommend using this on any computer. However it does demonstrate some useful functionality!
Here's the gist of simulating keypresses in windows- you have a couple options, the most predominate the keybd_event() function above. There are also other references you may wish to view:
Software Simulation Intro && MSDN
You also have the option of writing a driver to create the input, here are some possibly relevant links:
-WikiBook intro
-c++ vs asm
-osronine
-MSDN Drivers
-Driver Interrupts
Subscribe to:
Posts (Atom)