当前位置:天才代写 > 作业代写,留学生作业代写-北美、澳洲、英国等靠谱代写 > Hash Lab代写 哈希实验代写 COSC 3319代写

Hash Lab代写 哈希实验代写 COSC 3319代写

2020-08-18 15:34 星期二 所属: 作业代写,留学生作业代写-北美、澳洲、英国等靠谱代写 浏览:917

Hash Lab代写

Hash Lab    COSC 3319    Fall    2018    Burris

Hash Lab代写

Due: This lab will not be accepted after Wednesday November 21, 2018.

Hash Lab代写 Hash Lab COSC 3319 The hash address is to be calculated using folding combined with the division remainder technique

Hash Lab代写
Hash Lab代写
For your convenience a file of 200+ random words and names (Words200D16) has been provided on Blackboard.

Each line of text in the file is exactly 16 characters in length with the word left justified.  You may utilize any code developed in class directly in the lab.  While not initially apparent, this lab will be more of a thought problem than coding problem.  A careful examination of the sample code utilized in class will reveal a great deal of the code required for the lab has already been developed in class.Hash Lab代写

 Indeed, with so many examples, I assume you should be able to complete the “A” option code with little trouble.  Hence grading will emphasize evaluation and presentation of results for  correctly coded programs.  Be professional grade!

“C” Option:    Hash Lab代写

Assume a main memory hash table of size 128. The hash address is to be calculated using folding combined with the division remainder technique.  The hash address must be calculated as follows:

HA = ( (Key[1] * 512 + Key[4] / 7 + Key[6] / 7) / 256 ) modulo 128.

All alphabetic/numeric characters in a key are left justified.  Keys containing less than 16 alphabetic/numeric characters are padded with spaces on the right to a total of 16 characters.  Hash Lab代写

For example, it the string contains the value “ABCDEFGHIJK45678” then the hash address would be HA ß ( ( ‘A’ * 512 + ‘D’ / 7 + ‘F’ / 7) / 256 ) modulo 128.  I have never used this particular function but anticipate it will be substantially less than optimal generating a plethora of collisions.  All characters must be treated as positive integers in all steps of the calculation!

I recommend using a long_integer to hold the intermediate results of the hash calculation.   Hash Lab代写

Remember a “slice” in Ada allows the user to treat a substring as a single unit.  Given str has the value “ABCD” str(2..3) refers to the characters in positions 2 through 3 ) as a group from the string str, i.e., ”BC.”  “str(2..2) would be the second character in the string.  I am assuming you have instantiated a function which converts a  character (8 bits per ASCII character) to a long integer (32 bits) so overflow will not occur in the sum.

Each entry placed in the hash table must be a record with 3 fields.  The first filed is the key, the second the initial hash address, and the third field is the number of probes to insert the key in the table counting the initial hash address as the first probe.

A) Create a hash table in main memory and fill it 50% full.  Hash Lab代写

Use the linear probe technique developed in class to handle collisions.  Now look up the first 30 entries placed in the table.  Print the minimum, maximum, and average number of probes required to locate the first 30 keys placed in the table.  Now search for the last 30 keys placed in the table.  Print the minimum, maximum, and average number of probes required to locate the last 30 keys placed in the table.

Print the contents of the hash table clearly indicating open entries (this should allow you to see the primary/secondary clustering effect).  Calculate and print the theoretical expected number of probes to locate a random item in the table.  Explain your empirical results in light of the theoretical results.  Your grade points will be highly dependent on your explanation!

B) Create a hash table in main memory and fill it 90% full.Hash Lab代写

 Use the linear probe technique developed in class to handle collisions.  Now look up the first 30 entries placed in the table.  Print the minimum, maximum, and average number of probes required to locate the first 30 keys placed in the table.  Now search for the last 30 keys placed in the table.

YOU MUST PHYSICALL SEARCH FOR EACH KEY TO CALCULATE THE STATISTICS!  Print the minimum, maximum, and average number of probes required to locate the last 30 keys placed in the table.  You must start filling the table with the same keys in the same order as used when only filling the table 40% full.  Print the contents of the table clearly indicating open entries (this should allow you to see the primary clustering effect).  Hash Lab代写

Calculate and print the theoretical expected number of probes to locate a random item in the table.  Discuss your empirical results in light of the theoretical results.  Your grade points will be highly dependent on your explanation!

C) Repeat A and B above but use the random probe for handling collisions as developed in class.Hash Lab代写

 When you print the contents of the table you should be able to visually see the secondary clustering affect.  Calculate and print the theoretical expected number of probes to locate a random item in the table.  Discuss your empirical results in light of the theoretical results.  Your grade points will be highly dependent on your explanation!

D) Present all your results in a neat tabular format (typed naturally).  Compare your results to the theoretical results.Hash Lab代写

 If there are differences, please explain why.  I expect you to physically calculate the theoretical values for comparison to your empirical results for both the linear and random probes!

You may not ask a friend, you may not look them up in some table!  Providing someone else with the results will not only cause them to fail the lab but you as well.  You may however teach them to use a calculator, spreadsheet, log tables, or other techniques.

E) My required hash function has multiple weaknesses.Hash Lab代写

 Criticize the hash function on a technical basis.  To receive full credit, you must state clearly and explicitly state why my hash function should fail!  Based on your criticism, write a better hash function.  You must explain explicitly why your hash function should be better from both a theoretical and empirical standpoint.  

You will not receive credit for simply writing a hash function that performs better. Implement the hash function and generate the same results as required for parts A thru D presented in tabular format for comparison.  Formally evaluate the results as part of your lab (typed evaluation).  The results for all parts of the lab should appear in a single table.

 Shame on you if your hash function’s performance does not exceed the theoretical values for both the linear and random probe collision handling techniques.   Script Kiddies may have trouble evaluating the failures of my hash function and creating a better function.

“B” Option: Hash Lab代写

You need not complete the “C” option using a main memory table.  Rather, complete the “C” option using a random access (relative) file for the hash table.  The hash table must never appear in main memory!  Be sure to address all parts the “C” option.

A relative file is preferred for this option.  You may however use a commercial database product accessed from your “C,” C++, C#, Java or Ada program if desired rather than a relative file.  If a database is utilized, the primary key must be the hash address calculated as specified above.

“A” Option:    Hash Lab代写

Do both the “C” and “B” options.  Professionally compare the results.

Hash Lab代写
Hash Lab代写

 

 

 

 

 

 

 

 

更多其他:app代写  assignment代写 code代写 CS代写 cs作业代写 project代写 python代写 report代写 r作业代写 r语言代写  CS代写

合作平台:天才代写 幽灵代写  写手招聘 Essay代写

 

天才代写-代写联系方式