Skip to main content

PROBLEM SOLVING AND PYTHON PROGRAMMING QUIZ

1) What is the first step in problem-solving? A) Writing code B) Debugging C) Understanding the problem D) Optimizing the solution Answer: C 2) Which of these is not a step in the problem-solving process? A) Algorithm development B) Problem analysis C) Random guessing D) Testing and debugging Answer: C 3) What is an algorithm? A) A high-level programming language B) A step-by-step procedure to solve a problem C) A flowchart D) A data structure Answer: B 4) Which of these is the simplest data structure for representing a sequence of elements? A) Dictionary B) List C) Set D) Tuple Answer: B 5) What does a flowchart represent? A) Errors in a program B) A graphical representation of an algorithm C) The final solution to a problem D) A set of Python modules Answer: B 6) What is pseudocode? A) Code written in Python B) Fake code written for fun C) An informal high-level description of an algorithm D) A tool for testing code Answer: C 7) Which of the following tools is NOT commonly used in pr...

Allocation Methods

Allocation Methods
There are three main methods of storing files on disks: 
* contiguous, 
* linked, and 
* indexed.

Contiguous Allocation
* Contiguous Allocation requires that all blocks of a file be kept together continously.
* Performance is very fast, because reading following blocks of the same file generally requires no movement of the disk heads, or at most one small step to the next adjacent cylinder.
* Storage allocation involves the same issues discussed earlier for the allocation of contiguous blocks of memory ( first fit, best fit, fragmentation problems, etc. ) The distinction is that the high time fine required for moving the disk heads from spot to spot may now justify the benefits of keeping files continously when possible.
* ( Even file systems that do not by default store files contiguously can benefit from certain utilities that compact the disk and make all files contiguous in the process. )
* Problems can raise when files grow, or if the exact size of a file is unknown at creation time:
• Over-estimation of the file's final size increases external segmentation and wastes disk space.
• Under-estimation may need that a file be moved or a process aborted if the file 
grows beyond its originally allocated space.
• If a file grows slowly over a long time period and the total final space must be 
allocated initially, then a lot of space becomes not usable before the file fills the space.
* A variation is to allocate file space in large contiguous blocks, called extents. When a file outgrows its original extent, then an additional one is allocated. ( For example an extent may be the size of a complete track or even cylinder, aligned on an appropriate track or cylinder boundary) The high-performance files system Veritas uses extents to optimize performance.
Linked Allocation
* Disk files can be saved as linked lists, with the expense of the storage space consumed by each link. ( E.g. a block may be 508 bytes instead of 512. )
* Linked allocation involves no external fragmentation, does not require pre-known filesizes, and allows files to grow dynamically at any time.
* Unfortunately linked allocation is only efficient for continous access files, as random access requires starting at the beginning of the list for each new location access.
* Allocating clusters of blocks decreases the space wasted by pointers, at the cost of internal fragmentation.
* Another big problem with linked allocation is reliability if a pointer is lost or fault. Doubly linked lists provide some protection, at the cost of additional overhead and wasted space.
* The File Allocation Table, FAT, used by DOS is a difference of linked allocation, where all the links are stored in a separate table at the beginning of the disk. The benefit of this approach is that the FAT table can be cached in memory, greatly improving random access speeds.
Indexed Allocation
* Indexed Allocation groups all of the indexes for accessing each file into a common block ( for that file ), as opposed to spreading them all over the disk or storing them in a FAT table.
* Some disk space is wasted ( relative to linked lists or FAT tables ) because an entire index block must be allocated for each file, regardless of how many data blocks the file contains. This leads to questions of how big the index block should be, and how it should be implemented. There are several approaches:
Linked Scheme - An index block is one disk block, which can be read and written in a single disk operation. The first index block contains some header information, the first N block addresses, and if necessary a pointer to additional linked index blocks.
Multi-Level Index - The first index block contains a set of pointers to secondary 
index blocks, which in back contain pointers to the actual data blocks.
Combined Scheme - This is the scheme used in UNIX inodes, in which the first 
12 or so data block pointers are store directly in the inode, and then singly, 
doubly, and triply indirect pointers provide access to more data blocks as needed. 
( See below. ) The advantage of this scheme is that for small files ( which many are ), the data blocks are readily accessible (up to 48K with 4K block sizes); files up to about 4144K ( using 4K blocks ) are accessible with only a single indirect 
block ( which can be cached ), and huge files are still accessible using a relatively 
small number of disk accesses ( larger in theory than can be addressed by a 32-bit 
address, which is why some systems have moved to 64-bit file pointers. )
Performance
* The optimal allocation method is different for sequential access files than for random access files, and is also different for small files than for large files.
* Some systems support more than one allocation method, which may require specifying how the file is to be used (sequential or random access ) at the time it is allocated. Such systems also provide conversion utilities.
* Some systems have been known to use contiguous access for small files, and 
automatically switch to an indexed scheme when file sizes surpass a certain threshold.
* And of course some systems adjust their allocation schemes ( e.g. block sizes ) to best match the characteristics of the hardware for optimum performance.

Popular posts from this blog

Introduction to C Programs

INTRODUCTION The programming language ‘C’ was developed by Dennis Ritchie in the early 1970s at Bell Laboratories. Although C was first developed for writing system software, today it has become such a famous language that a various of software programs are written using this language. The main advantage of using C for programming is that it can be easily used on different types of computers. Many other programming languages such as C++ and Java are also based on C which means that you will be able to learn them easily in the future. Today, C is mostly used with the UNIX operating system. Structure of a C program A C program contains one or more functions, where a function is defined as a group of statements that perform a well-defined task.The program defines the structure of a C program. The statements in a function are written in a logical series to perform a particular task. The most important function is the main() function and is a part of every C program. Rather, the execution o...

Performance

Performance ( Optional ) * The I/O system is a main factor in overall system performance, and can place heavy loads on other main components of the system ( interrupt handling, process switching, bus contention, memory access and CPU load for device drivers just to name a few. ) * Interrupt handling can be relatively costly ( slow ), which causes programmed I/O to be faster than interrupt driven I/O when the time spent busy waiting is not excessive. * Network traffic can also loads a heavy load on the system. Consider for example the sequence of events that occur when a single character is typed in a telnet session, as shown in figure( And the fact that a similar group of events must happen in reverse to echo back the character that was typed. ) Sun uses in-kernel threads for the telnet daemon, improving the supportable number of simultaneous telnet sessions from the hundreds to the thousands.   fig: Intercomputer communications. * Rather systems use front-end processor...

Mathematics

MATHEMATICS           Mathematics is the science that deals with shapes, quantities and arrangements. Archmedes is known as the father of Mathematics (287BC-212BC). Mathematics seek and use patterns to formulates new conjuctures.They resove truth or false by using mathematical proof. Mathematics developed by counting, calculation, Measurements, Shapes and motion of physical objects.  Definition Mathematics has no general accepted definition. Until 18th century Aristotle defined mathematics as "the science of quantity". Many mathematicans take no interest in definition they simply say "Mathematics is what Mathematican do". Three leading definition of mathematics today are logicist, intutionist, and formalist. Logicist - In terms of Benjamin peirce, the definition of mathematics in terms of logic are "the science that draws necessary conclusion" and also said that " All mathematics is symbolic logic" by Mathematician Rusell. Intutionist - L.E.J.Bro...