首页
网站开发
桌面应用
管理软件
微信开发
App开发
嵌入式软件
工具软件
数据采集与分析
其他
首页
>
> 详细
data编程代写、代做Python,Java程序
项目预算:
开发周期:
发布时间:
要求地区:
Data Structures and Algorithms 1 (2023)
CA Exercise 2 – Baking Information System
The objective of this CA exercise is to create an application for storing and retrieving information on
baked goods (e.g. cakes, breads, biscuits, etc.) and the ingredients/components (e.g. flour, eggs, sugar,
etc.) that comprise them. The application should include both hashing and sorting functionality, and
provide a graphical user interface.
The application should allow/support the following:
The addition of new baked goods to the system. These might be cakes, breads, biscuits, tarts,
pies, etc.
o Baked good name, place/country of origin, textual description, and an image/picture of
the completed baked good (as a URL) are among key data to store.
The addition of new baking ingredients/components to the system. Examples are flour, eggs,
milk, chocolate, sugar, alcoholic spirits, fruits, nuts, etc. Anything that could be used to make a
baked good could be added as an ingredient/component.
o Name, textual description, and calories (as kcal per 100g/ml) are among key data to
store.
Ability to create recipes for baked goods that associate ingredients/components with the baked
goods they feature in, and the quantities (in grams or millilitres as appropriate) to use therein.
Note that a given ingredient could be used in various baked goods but in different
amounts/quantities.
Ability to edit/update/delete baked goods, recipes, and ingredients.
Ability to search for baked goods (including recipes) and ingredients using some
parameters/options. The search might be: by name, by description keyword, etc. The key thing
is that a search facility is provided with some (minimum of 2) search options.
Listings of search results (for both baked goods and ingredients) should be appropriately sorted
depending on the chosen search parameters/options. The sorting could be (1) alphabetical by
name or (2) by calories.
o Note that calories would have to be calculated for a baked good comprising various
ingredients of varying quantities and calories e.g. using 50g of dark chocolate when dark
chocolate has 500kcal per 100g => 250kcal is added to the total calories for the baked
good (and so on for all other ingredients in the baked good to arrive at the final calories
count).
o Other sorting options/parameters can also be provided, but alphabetical and calories
sorting are the key ones to implement.
The system should support some level of interactive “drill down” for additional detail or
navigation/browsing.
o For instance, searching for baked goods containing chocolate should provide a list of any
chocolate-containing baked good. One baked good in the list could then be clicked on to
see more information specifically on that baked good; that detail could include a list of
ingredients in the baked good; clicking on any ingredient opens up details on the
ingredient, including a list of all baked good containing that ingredient; and so on.
2
The system should support some form of persistence whereby the internal data is saved to a file
on exit, and reloaded for use on the next execution. You could use e.g. binary files, XML files,
plain text files, or anything else that provides an image/snapshot of all internal data.
o There is no need to look to databases or anything like that. A single snapshot/image file
is fine for our purposes.
Notes
This is a team CA exercise. Students should find/choose their own partners.
You will have to demonstrate this CA exercise in the lab sessions and you will be interviewed
individually on various aspects of it. You are expected to be able to answer all questions on all
code individually (so make sure that you understand all code, including the parts that your
teammate wrote).
This CA exercise is worth 35% of your overall module mark.
As with CA Exercise 1, you cannot use any existing Java collections or data structures classes (e.g.
ArrayList, LinkedList, or any other class that implements the Collection interface or any of its
children – if in doubt, ask me!). You essentially have to implement the required data structures
and algorithms from scratch and from first principles (in line with the module learning
outcomes).
o You are free to reuse any of your generic code from CA Exercise 1.
o You can use a regular array for your hash table(s) only.
You also cannot use any sorting or searching methods provided by Java in e.g. the Arrays or
Collections class (or any third party library equivalents). You should implement any searching
and sorting routines from scratch. Again, this is a learning exercise, and in line with the module
learning outcomes.
o Note that you cannot use a bubble sort either (as this is the full example provided in the
course notes, and I don’t want you to just copy-paste that). Use any other sorting
algorithm except a regular bubble sort for this reason.
You have to use hashing as part of the project to avoid (excessive) linear/sequential searching.
For instance, a custom hash function should be used for retrieving details on a specific baked
good or ingredient when searching. Again, you have to provide your own implementation of
hashing.
You have to provide a graphical user interface for the system. Exactly what your interface looks
like, though, is up to you.
o You can choose to implement a command line interface if you wish.
Remember that the key point of this CA exercise is to demonstrate knowledge and proficiency
with hashing and sorting in particular. Keep this in mind!
3
Indicative Marking Scheme
Appropriate custom ADTs for baked goods, ingredients, etc. = 10%
Create/add facilities (baked goods, recipes and ingredients) = 10%
Edit/update/delete facilities (baked goods, recipes and ingredients) = 10%
Search and listing facilities (multiple search options; baked goods and ingredients) = 15%
Sorting of search results/listings (alphabetical and total calories; baked goods and ingredients) =
10%
Hashing for individual search/lookup (baked goods and ingredients) = 10%
Persistence facility (saving and loading data) = 10%
graphical user interface = 10%
JUnit testing (minimum of 6-8 useful unit tests) = 5%
General (commenting, style, logical approach, completeness, etc.) = 10%
软件开发、广告设计客服
QQ:99515681
邮箱:99515681@qq.com
工作时间:8:00-23:00
微信:codinghelp
热点项目
更多
com1008代做、代写java程序设计
2025-01-12
ele000042c代写、代做c/c++编程...
2025-01-12
代写pls 21-application of co...
2025-01-11
代做isom 5745 business and o...
2025-01-11
代做ada600 dissertation 2024...
2025-01-11
代写125.811 advanced risk an...
2025-01-11
代做civ2235—structural mate...
2025-01-11
代做cs/math 240: introductio...
2025-01-11
代做busi4567 corporate finan...
2025-01-11
代写(07 36334) financial sta...
2025-01-11
代做geog0093 conservation an...
2025-01-11
代做mech e4320 (fall 2024): ...
2025-01-11
代写busi4567 corporate finan...
2025-01-11
热点标签
mktg2509
csci 2600
38170
lng302
csse3010
phas3226
77938
arch1162
engn4536/engn6536
acx5903
comp151101
phl245
cse12
comp9312
stat3016/6016
phas0038
comp2140
6qqmb312
xjco3011
rest0005
ematm0051
5qqmn219
lubs5062m
eee8155
cege0100
eap033
artd1109
mat246
etc3430
ecmm462
mis102
inft6800
ddes9903
comp6521
comp9517
comp3331/9331
comp4337
comp6008
comp9414
bu.231.790.81
man00150m
csb352h
math1041
eengm4100
isys1002
08
6057cem
mktg3504
mthm036
mtrx1701
mth3241
eeee3086
cmp-7038b
cmp-7000a
ints4010
econ2151
infs5710
fins5516
fin3309
fins5510
gsoe9340
math2007
math2036
soee5010
mark3088
infs3605
elec9714
comp2271
ma214
comp2211
infs3604
600426
sit254
acct3091
bbt405
msin0116
com107/com113
mark5826
sit120
comp9021
eco2101
eeen40700
cs253
ece3114
ecmm447
chns3000
math377
itd102
comp9444
comp(2041|9044)
econ0060
econ7230
mgt001371
ecs-323
cs6250
mgdi60012
mdia2012
comm221001
comm5000
ma1008
engl642
econ241
com333
math367
mis201
nbs-7041x
meek16104
econ2003
comm1190
mbas902
comp-1027
dpst1091
comp7315
eppd1033
m06
ee3025
msci231
bb113/bbs1063
fc709
comp3425
comp9417
econ42915
cb9101
math1102e
chme0017
fc307
mkt60104
5522usst
litr1-uc6201.200
ee1102
cosc2803
math39512
omp9727
int2067/int5051
bsb151
mgt253
fc021
babs2202
mis2002s
phya21
18-213
cege0012
mdia1002
math38032
mech5125
07
cisc102
mgx3110
cs240
11175
fin3020s
eco3420
ictten622
comp9727
cpt111
de114102d
mgm320h5s
bafi1019
math21112
efim20036
mn-3503
fins5568
110.807
bcpm000028
info6030
bma0092
bcpm0054
math20212
ce335
cs365
cenv6141
ftec5580
math2010
ec3450
comm1170
ecmt1010
csci-ua.0480-003
econ12-200
ib3960
ectb60h3f
cs247—assignment
tk3163
ics3u
ib3j80
comp20008
comp9334
eppd1063
acct2343
cct109
isys1055/3412
math350-real
math2014
eec180
stat141b
econ2101
msinm014/msing014/msing014b
fit2004
comp643
bu1002
cm2030
联系我们
- QQ: 9951568
© 2021
www.rj363.com
软件定制开发网!