COMP20005 Intro. to Numerical Computation in C

Hello, if you have any need, please feel free to consult us, this is my wechat: wx91due

School of Computing and Information Systems

COMP20005 Intro. to Numerical Computation in C

Semester 2, 2024

Assignment 2

Due: 4:00 pm Thursday 17th October 2024

Version 1.0

Learning Outcomes

In this assignment, you will demonstrate your understanding of arrays and structures, and use them together with functions. You will further practise your skills in program design and debugging.

The Story...

There are over 12 million credit cards in Australia,  and the number is over 7 billion worldwide.  This is a goldmine for cybercriminals who make unauthorised payments to obtain goods or services (i.e.,  credit  card fraud). In the 2022-2023 financial year, it was estimated that 1.8 million people in Australia experienced card fraud.   Banks and credit card companies are strongly motivated to develop anti-fraud technologies.  They prevented two-thirds of the attempted card fraud in the UK in 2018,  but this is a never-ending war.

There are various anti-fraud algorithms. The core of those algorithms are rules and statistics (now advanced machine learning algorithms) to classify whether a transaction is abnormal and likely to be fraudulent.  For example,  a transaction well beyond the credit limit of a card is likely to be fraudulent,  and  so are two transactions of the same card issued at almost the same time but from two different cities.

Your Task

In this assignment, you will write a program to process a list of credit card and transaction records  (as exemplified below) and identify fraudulent transactions.  You do not need to  be  an  anti-fraud expert.

fhlt2p  8000  500

hmqe2v  1000  800

q5g8d8  2000  1000

sqx7pb  20000  5000

swi6ea  250  100

@@@@@@@@@@

s34zzeup6b  q5g8d8  2024:09:01:04:52:46  548

lusmddyzp9  fhlt2p  2024:09:03:06:18:22  9198

vd00nc9qb8  fhlt2p  2024:09:07:08:42:03  72

0het8hcrda  sqx7pb  2024:09:10:12:10:53  610

toxesmipak  q5g8d8  2024:09:10:15:14:54  936

k3hn309eep  sqx7pb  2024:09:10:19:51:34  489

slvazil8t5  fhlt2p  2024:09:17:22:37:49  922

wkhispe89i  q5g8d8  2024:09:21:23:34:27  2809

yhnxcl0ked  hmqe2v  2024:09:26:23:12:08  433

adezmz9pqk  swi6ea  2024:09:26:23:17:09  200

The input starts with a list of credit card records sorted  by card ID. There are at least 1 and at most 50 cards. Each credit card occupies one line with three fields separated by a single whitespace: unique card ID (6 alphanumeric characters; no upper-case letters), daily limit (the total amount that can be spent in a day), and transaction limit (the amount that can be spent in a transaction). Both limits are positive integers that can be represented by int variables. The transaction limit does not exceed the daily limit.

The line  “@@@@@@@@@@” indicates the end of credit card records and the start of transactions.

The transactions are sorted by date and time. There are at least 1 and at most 100 transactions. Each transaction occupies one line with four fields separated by a single whitespace:  unique transaction ID  (10 alphanumeric characters; no upper-case letters), card ID (6 alphanumeric characters; no upper-case letters; must have appeared in the card records), transaction date and time (year:month:day:hour:minute:second, four digits for year and two digits for each of the other components), and transaction amount (a positive integer, for simplicity).

You may assume that the input data is  always in valid format.  No  input format  validity  checking is  needed.

3.1    Stage 1 - Read the First Credit Card Record (6 Marks)

Your first task is to design a struct to represent a credit card record.  You will then read in a credit card record from the input data, and output it in the following format (where “mac:” is the command prompt):

mac:  ./program  < test0 .txt

Stage  1

==========

Card  id:  fhlt2p

Daily  limit:  8000

Transaction  limit:  500

You can also read all input data before printing out for Stage 1. You may (and should) add more functions as appropriate.

3.2    Stage 2 - Read the Rest of Credit Card Records (5 Marks)

Next, continue to read all credit card records. You need to design a proper data structure to store the records read. An array will do the job nicely. When this stage is done, your program should output: the total number of credit card records read, the credit card with the largest daily limit  (if there is a tie, print the card with the smallest ID among the tied ones), and the average transaction limit per card (up to two digits after the decimal point, by using “%.2f” in printf()). The output of this stage based on the sample input is:

Stage  2

==========

Number  of  credit  cards:  5

Card  with  the  largest  daily  limit:  sqx7pb

Average  transaction  limit:  1480 .00

3.3 Stage 3 - Read the Transactions (5 Marks)

Your third task is to design a struct to represent a transaction, read in the transactions, store them in another array, and output the total number of transactions and the credit card with the largest number of transactions (if there is a tie, print the card with the smallest ID among the tied ones).  The output in this stage for the sample input above should be:

Stage  3

==========

Number  of  transactions:  10

Card  with  the  largest  number  of  transactions:  fhlt2p

You may assume that all credit card IDs in the transactions can be found in the credit card records.

3.4 Stage 4 - Check for Fraudulent Transactions (4 Marks)

The next stage is to check whether a transaction maybe fraudulent. You will go through the transactions. For each transaction, you need to check if it exceeds the transaction limit or the daily limit of the corresponding credit card.

A sample output given the input example above is (note a final newline character ‘\n’ at the end):

Stage  4

==========

s34zzeup6b  WITHIN_BOTH_LIMITS

lusmddyzp9  EXCEED_BOTH_LIMITS  /*  9198  >  8000  and  9198  >  500  */

vd00nc9qb8  WITHIN_BOTH_LIMITS

0het8hcrda  WITHIN_BOTH_LIMITS

toxesmipak  WITHIN_BOTH_LIMITS

k3hn309eep  WITHIN_BOTH_LIMITS

slvazil8t5  EXCEED_TRANS_LIMIT  /*  922  >  500  */

wkhispe89i  EXCEED_BOTH_LIMITS  /*  2809  >  2000  and  2809  >  1000  */

yhnxcl0ked  WITHIN_BOTH_LIMITS

adezmz9pqk  EXCEED_TRANS_LIMIT  /*  200  >  100  */

For  a  challenge,  see  if you  can  design  an  algorithm  that  only needs  to go  through  the  transactions  once  for completing Stage 4 .  Hint:   To  achieve  such  an  algorithm,  you  may  need  to  modify  the  credit  card  struct  to store  additional information.

4    Submission and Assessment

This assignment is worth 20% of the final mark. A detailed marking scheme will be provided on LMS.

Submitting your codeTo submit your code, you will need to:  (1) Log in to LMS subject site,  (2) Nav- igate to “Assignment 2” in the “Assignments” page,  (3) Click on “Load Assignment 2 in a new window”, and (4) follow the instructions on the Gradescope “Assignment 2” page and click on the “Submit” link to make a submission.  You can submit  as many times as you want to.   Only  the  last  submission  made  before the  deadline  will  be  marked.   Submissions made after the deadline will be marked with late penalties as de- tailed at the end of this section. Do not submit after the deadline unless a late submission is intended. Two hidden tests will be run for marking purposes.  Results of these tests will be released after the marking is done.

You can (and should) submit both early and often – to check that your program compiles correctly on our test system, which may have some different characteristics to your own machines.

Testing on your own computer. You will be given a sample test file test0 .txt and the sample output test0-output .txt. You can test your code on your own machine with the following command and compare the output with test0-output .txt:

mac:  ./program  < test0.txt /* Here ‘<’ feeds the data from test0.txt into program */

Note that we are using the following command to compile your code on the submission testing system (we name the source code file program.c).

gcc  -Wall  -std=c17  -o  program  program .c  -lm

The flag “-std=c17” enables the compiler to use a modern standard of the C language – C17.  To ensure that your submission works properly on the submission system, you should use this command to compile your code on your local machine as well.

You may discuss your work with others, but what gets typed into your program must be individual work, not from anyone else.

• Do not give (hard or soft) copies of your work to anyone else.

• Do not “lend” your memory stick to others.

• Do not leave your laptop unlocked in the lab or library.

• Do not upload your assignment solutions onto Github or any other public code repositories.

•  Do not ask others to give you their programs “just so that I can take a look and get some ideas,I won’t copy, honest” .

The best way to help your friends in this regard is to say a very firm  “no” when they ask for a copy of,  or to see, your program, pointing out that your  “no”,  and their  acceptance of that decision, is the only  thing that will preserve your friendship.  A  sophisticated program  that undertakes  deep  structural  analysis  of C code  identifying  regions  of similarity  will  be  run  over  all  submissions  in   “compare  every  pair”  mode.   See https://academichonesty.unimelb.edu.au for more information.

Deadline:  Programs not submitted by 4:00 pm Thursday 17th October 2024 will lose penalty marks at the rate of 3 marks per day or part day late.  Late submissions after 4:00 pm Sunday 20th October 2024 will not be accepted.

发表评论

电子邮件地址不会被公开。 必填项已用*标注