cwtests/cw02/factors.while
author Christian Urban <christian.urban@kcl.ac.uk>
Sat, 04 Dec 2021 00:49:34 +0000
changeset 860 abf63cd5e11b
parent 856 6a16964aed93
child 933 4d9674598682
permissions -rw-r--r--
updated
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
833
7c3b8bb4a174 cwupdates
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     1
// Find all factors of a given input number
7c3b8bb4a174 cwupdates
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     2
7c3b8bb4a174 cwupdates
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     3
860
abf63cd5e11b updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 856
diff changeset
     4
write "Input n please: ";
833
7c3b8bb4a174 cwupdates
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     5
read n;
860
abf63cd5e11b updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 856
diff changeset
     6
write "The factors of n are: \n";
833
7c3b8bb4a174 cwupdates
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     7
f := 2;
7c3b8bb4a174 cwupdates
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
     8
while (f < n / 2 + 1) do {
860
abf63cd5e11b updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 856
diff changeset
     9
  if ((n / f) * f == n)
abf63cd5e11b updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 856
diff changeset
    10
  then { write(f); write("\n") }
abf63cd5e11b updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 856
diff changeset
    11
  else { skip };
833
7c3b8bb4a174 cwupdates
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    12
  f := f + 1
7c3b8bb4a174 cwupdates
Christian Urban <christian.urban@kcl.ac.uk>
parents:
diff changeset
    13
}