• 0

Pseudocode help


Question

Hi guys just wanted some help with Pseudocode. I just can get my head around it all I dont know why but I am really struggling. I have been asked to do the following. A program is needed that can accept 10 numbers as input from the user. The program should output the following information:

The sum of the numbers,

The mean of the numbers,

The median value for the numbers

any pointers

thanks

Link to comment
https://www.neowin.net/forum/topic/1129406-pseudocode-help/
Share on other sites

14 answers to this question

Recommended Posts

  • 0

Don't know what language you're using so I can't make it particularly specific:

int sum = 0;
int mean = 0;
int median = 0;
int num4 = 0;
int num5 = 0;
for count = 0 to 10 { // For all ten of the user's numbers
int num = get_number_from_user();
sum = sum + num;
if (count == 4) num4 = num; // If this is one of the two middle numbers, store it for calculating the median
if (count == 5) num5 = num;
}
mean = sum / 10;
// EDIT: See discussion below about calculating the median if the numbers aren't entered in order
//median = (num4 + num5) / 2; // Two middle numbers so the median is their average
print(sum + " " + mean + " " + median);[/CODE]

  • 0

Don't know what language you're using so I can't make it particularly specific:

int sum = 0;
int mean = 0;
int median = 0;
int num4 = 0;
int num5 = 0;
for count = 0 to 10 { // For all ten of the user's numbers
  int num = get_number_from_user();
  sum = sum + num;
  if (count == 4) num4 = num; // If this is one of the two middle numbers, store it for calculating the median
  if (count == 5) num5 = num;
}
mean = sum / 10;
median = (num4 + num5) / 2; // Two middle numbers so the median is their average
print(sum + " " + mean + " " + median);[/CODE]


You are making the assumption that the user will input numbers in ascending numerical order.
I would suggest it needs to sort the numbers into ascending numerical order before trying to calculate the median.
Something like:
[code]int sum = 0;
int mean = 0;
int median = 0;
int count = 10;
int num[] = {0};

for int N = 1 to count {
  num[N] = get_number_from_user();
  sum += num[N];
}
mean = sum / count;
sort(num[]);
median = (num[5] + num[6]) / 2;
print(sum + " " + mean + " " + median);

  • 0

On a more serious note, it looks like you want your homework problem solved. Rather than handing it on a silver plate, would you mind showing us how far you've got already?

He asked for pseudocode instead of a solution which is certainly better than the average homework question around here. You still have to know what you're doing to a reasonable degree to get anything working from it.

You are making the assumption that the user will input numbers in ascending numerical order.

...

I would suggest it needs to sort the numbers into ascending numerical order before trying to calculate the median.

True, not sure why I was assuming they were sorted. Thanks for pointing that out.

  • 0

Im not asking for my homework to be done but a few pointers as I have been told that writing in pseudocode is the step in between the flow chart and the programming code, So when a programmer can look at this and they can make determine what I want.

The code I'm going to be using is VB.

This is what I have done so far.

BEGIN

PROMPT ?Enter Numbers?

ADD and STORE Numbers = SUM

ARRANGE Numbers in Ascending order

Calculate MEAN of Numbers and STORE = SUM / 10

Calculate the MEDIAN and store = Number 5 + Number 6 / 2

PRINT SUM

PRINT MEAN

PRINT MEDIAN

END

Can you tell me what you think.

thanks

  • 0

Then please accept my apologies.

Yes, that's more like pseudocode - unrelated to any language in particular, understandable even to a non-programmer.

In classes we quickly went to Pascal syntax to get closer to the code, but flowcharts seem so much easier to do if one stays with informal syntax such as this.

Some comments:

* Even when using informal syntax, division takes precedence over addition. So the Number 5 + Number 6 / 2 line is confusing, and might creep an error in code later, if one is not careful. Either use parenthesis outright or just write the definition of median - mean of the two middlemost numbers.

* Regardless of syntax, SORT would be probably be better term instead of ARRANGE. Using engineering terms still helps if you later have to elaborate on how exactly one does that (all algorithms "sort")

  • 0

so i could write it like this...

Calculate the MEDIAN and store = ((Number 5 + Number 6 ) / 2)

That's fine but the outer brackets are redundant. Wrapping the entire equation in brackets is the same as having none, so ((Number 5 + Number 6) / 2) is the same as (Number 5 + Number 6) / 2.

  • 0

FWIW, 5 + 6 is relative to the starting number. If you were just shoving the input into an array, it would be 0 - 9, and the median would be (4+5)/2. Unless specified, I would assume any pseudocode to count from zero.

Not sure if I'm misunderstanding what you're saying or if I'm just confused by your explanation, but the median is worked out as follows:-

1. Sort the numbers into ascending order.

2. If the number of numbers is odd, the median is the middle number.

3. If the number of numbers is even, the median is the mean of the middle two numbers.

Example 1:

1, 2, 3, 10, 11 - the median is 3 because it's the middle number.

Example 2:

1, 2, 3, 4, 10, 11 - median is 3.5, because you take the middle two numbers and work out the mean. (3 + 4) / 2 = 3.5.

  • 0

Must have meant array indexing - zero-based or one-based. Zero-based being very prevalent, but nevertheless not universal. We must not make assumptions - the very idea of pseudocode (of informal syntax) is meant to be readable (so one-based would be more natural) and easy to translate among different languages (even though *we* know that VB, zero-based, will be used).

If anything, writing only the definition of median would be the most acceptable.

  • 0

Must have meant array indexing - zero-based or one-based. Zero-based being very prevalent, but nevertheless not universal. We must not make assumptions - the very idea of pseudocode (of informal syntax) is meant to be readable (so one-based would be more natural) and easy to translate among different languages (even though *we* know that VB, zero-based, will be used).

If anything, writing only the definition of median would be the most acceptable.

Just reread his post and I agree he was probably talking about array indexing.

Pseudo code being language independent and supposed to be readable, I thought it would make more sense to use a one-based array. Clearly when translating it into actual code the user must make the necessary adjustments if it is a zero-based language.

  • 0

Must have meant array indexing - zero-based or one-based. Zero-based being very prevalent, but nevertheless not universal. We must not make assumptions - the very idea of pseudocode (of informal syntax) is meant to be readable (so one-based would be more natural) and easy to translate among different languages (even though *we* know that VB, zero-based, will be used).

If anything, writing only the definition of median would be the most acceptable.

Well, you know that 10 is going to be the number of inputs as well.

You could say MEDIAN = LENGTH OF ARRAY MODULO 2 ? ROUND UP ARRAY[LENGTH/2] : (ARRAY[LENGTH/2] + ARRAY[LENGTH/2 + 1]) / 2

Thereby negating the need to know the index or the number of inputs and defining median.

This topic is now closed to further replies.
  • Recently Browsing   0 members

    • No registered users viewing this page.
  • Posts

    • Ocenaudio 3.19.3 by Razvan Serea  Ocenaudio is a full featured, fast and easy to use audio and music editor. It is the ideal software for people who need to edit and analyze audio files without complications. Ocenaudio also has powerful features that will please more advanced users. To assist ocenaudio development, a powerful toolset of audio editing, analysis and manipulation called Ocen Framework was created. ocenaudio is also based on Qt framework, a well known library for cross-platform development. Cross-platform support ocenaudio is available for all major operating systems: Microsoft Windows, Mac OS X and Linux. Native applications are generated for each platform from a common source, in order to achieve excelent performance and seamless integration with the operating system. All versions of ocenaudio have a uniform set of features and the same graphical interface, so the skills you learn in one platform can be used in the others. VST plugins support Ocenaudio supports VST (Virtual Studio Technology) plugins, giving its users access to numerous effects. Like the native effects, VST effects can use real-time preview to aide configuration. Real-time preview of effects Applying effects such as EQ, gain and filtering is an important part of audio editing. However, it is very tricky to get the desired result by adjusting the controls configuration alone: you must listen the processed audio. To ease the configuration of audio effects, ocenaudio has a real time preview feature: you hear the processed signal while adjusting the controls. The effect configuration window also includes a miniature view of the selected audio signal. You can navigate on this miniature view in the same way as you do on the main interface, selecting parts that interest you and listening to the effect result in real time. Multiselection for delicate editions To speed up complex audio files editing, ocenaudio includes multi-selection. With this amazing tool, you can simultaneously select different portions of an audio file and listen, edit or even apply an effect to them. For example, if you want to normalize only the excerpts of an interview where the interviewee is talking, just select them and apply the effect. Eficient edition of large files With ocenaudio, there is no limit to the length or the quantity of the audio files you can edit. Using an advanced memory management system, the application keeps your files open without wasting any of your computer's memory. Even in files several hours long, common editing operations such as copy, cut or paste happen almost instantly. Fully featured spectrogram Besides offering an incredible waveform view of your audio files, ocenaudio has a powerful and complete spectrogram view. In this view, you can analyze the spectral content of your audio signal with maximum clarity. Advanced users will be surprised to find that the spectrogram settings are applied in real time. The display is updated immediately when altering features such as the number of frequency bands, window type and size and dynamic range of the display. Ocenaudio 3.19.3 changelog: Fixes issues with MP4 files with more than 8 channels Fixes incorrect VBR detection for some CBR MP3 files Other bug fixes and improvements Download: Ocenaudio 64-bit | Portable | ~40.0 MB (Freeware) Download: Ocenaudio for Linux and Mac OS View: Ocenaudio Homepage | Screenshot Get alerted to all of our Software updates on Twitter at @NeowinSoftware
    • DiskGenius 6.2.0.1829 - All Versions: Free, Lite & Portable by Razvan Serea DiskGenius is a full-featured partition manager, which is designed to optimize disk usage for Windows users. It will efficiently help you recover lost data, resize/split partition, backup files, edit hex data, check bad sectors, manage virtual disks, erase data, etc.. Create a system image backup for current Windows with simple clicks to keep the operating system under protection. DiskGenius key features: Partition Management - It can create format, resize, extend, backup, split, hide and clone partition, both MBR and GPT are supported. Disk and partition conversion - Convert dynamic disk to basic, convert virtual disk format and convert MBR to GPT, convert primary partition to logical. File recovery - It can recover files deleted or emptied form recycle bin, recover files from damaged partition or disk and recover files by file type and supports file preview and file filter. Partition recovery - It is the best partition recovery program in that it can recover files from damaged, corrupted and RAW partitions, search for lost partition and recover files from it, besides, it can fix partition table. RAID recovery - It can reconstruct Virtual RAID and recover files from it, and all RAID types are supported. Sector Editor - A Hex editor is embedded to help users edit raw hex data and recover data manually. Backup and Restore - It can backup and restore partition including system partition, hard disk and partition table. Bad Tracks - It can check and repair bad sectors for all storage devices; check hard disk S.M.A.R.T. information. Delete files permanently - It can delete files permanently so that they can't be recovered by any data recovery software. Virtual Disk - It supports virtual disks, including VMware, Virtual PC and Virtual Box. Create WinPE bootable disk and you can manage disk partition when system crashes or there is no operating system on your computer. Support FAT12/FAT16/FAt32/exFAT/NTFS/EXT2/EXT3/EXT4 file system format. DiskGenius 6.2.0.1829 changelog: Add the "Disk Speed Test" feature. Add the "Windows Boot Repair and Conversion" feature. Add the BMB21-2019 erase standard to the "Erase Sectors" feature. Add support for restoring an individual partition from a PMFX disk image file. Enhanced The "Verify Or Repair Bad Sectors/Blocks" feature displays disk read speed in the detection window during scanning. The "Quick Partition" dialog box allows users to quickly select the number of partitions by pressing the numeric keys 1, 2, 7, 8, or 9. The "Set Volume Name" dialog box supports selecting preset volume labels provided by the software. The "Copy Sectors" feature supports resuming copy tasks after modifying the number of skipped bad sectors. Add the "TRIM Optimization" option to the format dialog box. The "Clone Partition" and "Clone Disk" features perform TRIM optimization on target partitions or disks before cloning. Add support for Not Equal To search conditions (prefixed with "!") when searching hexadecimal data in the sector editor. Optimize the display of capacity values in the program interface to show two decimal places. Add a minimize button to dialogs that may require long processing time. Enhance support for the ReFS file system. Enhance support for newer HIF and MP4 formats when recovering files by type. Enhance support for the EXT4 file system. Enhance compatibility of the "File Recovery" feature with special data structures. Fixed Fixed the issue that the selected file system type automatically reverted to NTFS after changing it to exFAT or EXT4 in the "Quick Partition" dialog box. Fixed inaccurate Unicode string search results in the "Sector Editor" feature. Fixed the issue that exceptions might occur when adding multiple disks in the "Erase Sectors" feature. Fixed the issue that insufficient target disk space was incorrectly reported in some cases when cloning, backing up, or restoring disks. Fixed the issue that folder modification timestamps were not preserved when copying files from ReFS partitions. Fixed the issue that Excel-format reports generated by features such as file copying or bad sector checking could not be opened when the report contained more than one million rows. Fixed the issue that folders were not displayed in the exclude-folder dialog box when backing up partitions to image files. Fixed the issue that the "Erase Sectors" feature could not be executed in some cases. Download: DiskGenius 6.2.0.1829 | 63.9 MB (Freeware, paid upgrade available) Download: DiskGenius Portable 64-bit | 40.0 MB Download: DiskGenius Portable 32-bit | 36.0 MB Download: DiskGenius Lite 64-bit | 13.4 MB Download: DiskGenius Lite 32-bit | 11.6 MB View: DiskGenius Home Page | DiskGenius Screenshot Get alerted to all of our Software updates on Twitter at @NeowinSoftware
    • Really? Use a better search engine https://www.google.com/search?...ourceid=chrome&ie=UTF-8
  • Recent Achievements

    • Week One Done
      agatameier earned a badge
      Week One Done
    • One Month Later
      agatameier earned a badge
      One Month Later
    • Week One Done
      ssd21345 earned a badge
      Week One Done
    • Contributor
      MarkHughes4096 went up a rank
      Contributor
    • Dedicated
      jordanspringer earned a badge
      Dedicated
  • Popular Contributors

    1. 1
      +primortal
      513
    2. 2
      +Edouard
      183
    3. 3
      PsYcHoKiLLa
      144
    4. 4
      ATLien_0
      95
    5. 5
      Steven P.
      75
  • Tell a friend

    Love Neowin? Tell a friend!