• 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

    • BleachBit 6.0.1 Beta by Razvan Serea When your computer is getting full, BleachBit quickly frees disk space. When your information is only your business, BleachBit guards your privacy. With BleachBit you can free cache, delete cookies, clear Internet history, shred temporary files, delete logs, and discard junk you didn't know was there. Designed for Linux and Windows systems, it wipes clean thousands of applications including Firefox, Microsoft Edge, Google Chrome, Opera, Safari, and more. Beyond simply deleting files, BleachBit includes advanced features such as shredding files to prevent recovery, wiping free disk space to hide traces of files deleted by other applications, and vacuuming Firefox to make it faster. Better than free, BleachBit is open source. BleachBit has many useful features: Delete your private files so completely that "even God can't read them" according to South Carolina Representative Trey Gowdy. Simple operation: read the descriptions, check the boxes you want, click preview, and click delete. Multi-platform: Linux and Windows Free of charge and no money trail Free to share, learn, and modify (open source) No adware, spyware, malware, browser toolbars, or "value-added software" Translated to 64 languages besides American English Shred files to hide their contents and prevent data recovery Shred any file (such as a spreadsheet on your desktop) Overwrite free disk space to hide previously deleted files Portable app for Windows: run without installation Command line interface for scripting and automation CleanerML allows anyone to write a new cleaner using XML Automatically import and update winapp2.ini cleaner files (a separate download) giving Windows users access to 2500+ additional cleaners Frequent software updates with new features Going beyond standard deletion of files, BleachBit has several advanced cleaners: Clear the memory and swap on Linux Delete broken shortcuts on Linux Delete the Firefox URL history without deleting the whole file—with optional shredding Delete Linux localizations: delete languages you don't use. More powerful than localepurge and available on more Linux distributions. Clean APT for Debian, Ubuntu, Kubuntu, Xubuntu, and Linux Mint Find widely-scattered junk such as Thumbs.db and .DS_Store files. Execute yum clean for CentOS, Fedora, and Red Hat to remove cached package data Delete Windows registry keys—often where MRU (most recently used) lists are stored Delete the OpenOffice.org recent documents list without deleting the whole Common.xcu file Overwrite free disk space to hide previously files Vacuum Firefox, Google Chrome, Liferea, Thunderbird, and Yum databases: shrink files without removing data to save space and improve speed Surgically remove private information from .ini and JSON configuration files and SQLite3 databases without deleting the whole file Overwrite data in SQLite3 before deleting it to prevent recovery (optional) BleachBit 6.0.1 Beta release notes: BleachBit 6.0.1 beta is now available for testing. This maintenance-focused release includes bug fixes, updated translations, and a range of safe enhancements. This release fixes a Windows security issue that could allow arbitrary file deletion during privileged cleaning (reported by Zeze with TeamT5). It also adds new cleaners (including a DNS cache cleaner, Claude Code, and Visual Studio Code forks), support for multiple Chrome and Edge profiles, new deep scan options for developer directories like node_modules and venv, and safer, faster file shredding. All Platforms Added cleaners for Claude Code, DNS cache, and many Visual Studio Code forks. Added support for multiple Chrome and Edge profiles. Chrome can now clean downloaded AI models. Deep Scan can optionally remove venv, __pycache__, node_modules, and .angular directories. Deep Scan is faster by skipping directories on the keep list. File shredding is safer, faster, and leaves fewer recoverable traces. Improved handling of cookies, symlinks, Unicode filenames, external processes, and configuration files. Improved Expert Mode warnings and long warning dialogs. Fixed crashes related to cleaner detection, invalid Unicode, and malformed cleaner data. Clipboard is now cleared automatically after shredding files via paste operations. Linux Added AppImage support. Added cleaners for Visual Studio Code, Codeium, Librewolf (.deb), Transmission (Flatpak), and Profanity. Improved Linux trash detection, including Snap-installed applications and mounted drives. Fixed Wayland root CLI issues and several Snap-related problems. Improved package dependencies, AppStream metadata, and desktop file handling. Fixed startup crashes when Python Requests is unavailable. Windows Fixed a security vulnerability that could allow arbitrary file deletion when cleaning with elevated privileges. Added %WindowsSystem% variable support. Improved clipboard clearing using native Windows APIs. Improved installer experience on unsupported Windows versions. Reduced installer size and improved application robustness. Fixed Unicode handling, filename anonymization, Git revision reporting, and splash screen stability. [full release notes] Download: BleachBit 6.0 | Portable | ~20.0 MB (Open Source) View: BleachBit Home page | Screenshot Get alerted to all of our Software updates on Twitter at @NeowinSoftware
    • DriversCloud 12.1.6 by Razvan Serea With DriversCloud (formerly My-Config.com), you can explore your computer easily, safely and free. The application quickly scans your PC and identifies the hardware and software components. DriversCloud then establishes a list of the different drivers compatible with your OS and hardware. Download the drivers needed for the proper functioning of your computer. To detect your drivers, DriversCloud also displays a detailed summary of your hardware and software configuration, analyzes your BSOD, monitors in real-time your PC voltages and temperatures and lets you share your configuration online. Once the hardware components have been detected, you will be able to obtain with just a few clicks the latest drivers corresponding to the identified hardware. You can record your configuration on the site for free, and can get the corresponding URL to post the configuration to technical forums, e-mail and social networks. You can also download the detection result (the configuration) as a PDF file. To protect the user's privacy and data confidentiality, a 4-level confidentiality system was created that filters the XML marks and gives control to the user. The default level can be modified in the preferences. Using the maximum level will prevent the user from publishing his configuration and generating a corresponding PDF file. In non-connected mode, each XML configuration is stored on the server for one day (for practical reasons). However, you are given the opportunity to manually delete it. Created in 2004, and continually improved, My-Config.com has established itself on the web as a free service to PC users running Windows and Linux operating systems. The service is designed to work with the most common Internet browsers (Edge, Firefox, Chrome, Safari). Download: DriversCloud 64-bit | 20.0 MB (Freeware) Download: DriversCloud 32-bit | 18.9 MB Link: DriversCloud Home Page | Screenshot Get alerted to all of our Software updates on Twitter at @NeowinSoftware
  • 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
      516
    2. 2
      +Edouard
      189
    3. 3
      PsYcHoKiLLa
      148
    4. 4
      ATLien_0
      96
    5. 5
      Steven P.
      76
  • Tell a friend

    Love Neowin? Tell a friend!