blob: c8d7264e7cc11a90830090a900f895b8f0ebac2c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
/*
* Check if the current number is prime
*/
CREATE OR REPLACE FUNCTION f_is_prime( n int )
RETURNS bool
AS $CODE$
DECLARE
divisor int;
BEGIN
FOR divisor IN 2 .. ( n - 1 ) LOOP
IF mod( n, divisor ) = 0 THEN
RETURN false;
END IF;
END LOOP;
RETURN TRUE;
END
$CODE$
LANGUAGE plpgsql;
CREATE OR REPLACE FUNCTION f_semiprime_factors( n int )
RETURNS SETOF int
AS $CODE$
DECLARE
current_number int;
BEGIN
FOR current_number IN 1 .. n LOOP
IF f_is_prime( current_number ) AND mod( n, current_number ) = 0 AND f_is_prime( ( n / current_number ) ) THEN
RETURN NEXT current_number;
END IF;
END LOOP;
RETURN;
END
$CODE$
LANGUAGE plpgsql;
CREATE OR REPLACE FUNCTION f_is_semiprime( n int )
RETURNS bool
AS $CODE$
SELECT CASE count( * )
WHEN 0 THEN false
ELSE true
END
FROM f_semiprime_factors( n ) s;
$CODE$
LANGUAGE sql;
CREATE OR REPLACE FUNCTION f_find_semiprimes( lim int default 100 )
RETURNS SETOF int
AS $CODE$
DECLARE
n int;
BEGIN
n := 1;
WHILE n < lim LOOP
IF f_is_semiprime( n ) THEN
RETURN NEXT n;
END IF;
n := n + 1;
END LOOP;
RETURN;
END
$CODE$
LANGUAGE plpgsql;
|