aboutsummaryrefslogtreecommitdiff
path: root/challenge-326/luca-ferrari/plpgsql/ch-2.sql
blob: 030b495017b4e06f22600accdf8a5f1aa96385c0 (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
--
-- Perl Weekly Challenge 326
-- Task 2
-- See <https://perlweeklychallenge.org/blog/perl-weekly-challenge-326>
--

CREATE SCHEMA IF NOT EXISTS pwc326;

CREATE OR REPLACE FUNCTION
pwc326.task2_plpgsql( nums int[] )
RETURNS SETOF int
AS $CODE$
DECLARE
	i int;
	base int;
	times int;
BEGIN

	FOR i IN 1 .. array_length( nums, 1 ) - 1 LOOP
	    IF mod( i, 2 ) = 0 THEN
	       CONTINUE;
	    END IF;

	    base  := nums[ i ];
	    times := nums[ i + 1 ];


	    FOR j in 1 .. times LOOP
	    	RETURN NEXT base;
            END LOOP;
	END LOOP;

RETURN;
END
$CODE$
LANGUAGE plpgsql;