I just finished a homework problem for Computer Science 1 (yes, it’s homework, but hear me out!). Now, the assignment is 100% complete and working, so I don’t need help on it. My question involves the efficiency of an algorithm I’m using (we aren’t graded on algorithmic efficiency yet, I’m just really curious).
The function I’m about to present currently uses a modified version of the linear search algorithm (that I came up with, all by myself!) in order to check how many numbers on a given lottery ticket match the winning numbers, assuming that both the numbers on the ticket and the numbers drawn are in ascending order. I was wondering, is there any way to make this algorithm more efficient?
/*
* Function: ticketCheck
*
* @param struct ticket
* @param array winningNums[6]
*
* Takes in a ticket, counts how many numbers
* in the ticket match, and returns the number
* of matches.
*
* Uses a modified linear search algorithm,
* in which the index of the successor to the
* last matched number is used as the index of
* the first number tested for the next ticket value.
*
* @return int numMatches
*/
int ticketCheck( struct ticket ticket, int winningNums[6] )
{
int numMatches = 0;
int offset = 0;
int i;
int j;
for( i = 0; i < 6; i++ )
{
for( j = 0 + offset; j < 6; j++ )
{
if( ticket.ticketNum[i] == winningNums[j] )
{
numMatches++;
offset = j + 1;
break;
}
if( ticket.ticketNum[i] < winningNums[j] )
{
i++;
j--;
continue;
}
}
}
return numMatches;
}
It’s more or less there, but not quite. In most situations, it’s O(n), but it’s O(n^2) if every ticketNum is greater than every winningNum. (This is because the inner
jloop doesn’tbreakwhenj==6like it should, but runs the nextiiteration instead.)You want your algorithm to increment either
iorjat each step, and to terminate wheni==6orj==6. [Your algorithm almost satisfies this, as stated above.] As a result, you only need one loop:Clearly this is O(n); at each stage, it either increments
iorj, so the most steps it can do is 2*n-1. This has almost the same behaviour as your algorithm, but is easier to follow and easier to see that it’s correct.