DB/Oracle

Oracle DB10_조건문/반복문 연습문제

Codezoy 2019. 9. 30. 09:01



  • SQL 시작시 : SET SERVEROUTPUT ON;



  • 연습문제

-- 1.
-- 구구단(2단 ~ 9단)을 출력

-- 2.
-- 구구단(2단 ~ 9단)을 출력.
-- 2단은 2x2까지, 3단은 3x3까지, 4단은 4x4까지, ...

-- dbms_random.value(x, y) 함수는 x보다 크거나 같고, y보다 작은 난수(임의의 숫자)를 리턴합니다.
select dbms_random.value(0, 1) from dual;

-- 3. 무작위로 던진 동전에서 앞면과 뒷면이 나올 확률이 1/2임을 증명하세요.
-- (1) dbms_random.value(x, y) 함수를 사용해서 0 또는 1을 무작위로 출력하는 PL/SQL을 작성하세요.
-- (2) (1)에서 작성한 코드를 수정해서,
-- 난수가 0이면 '동전 앞면(head)', 1이면 '동전 뒷면(tail)'이라고 출력하는 PL/SQL을 작성하세요.
-- (3) 0 또는 1을 랜덤하게 만드는 과정((1) 코드)을 1000번 반복해서, 0과 1의 발생 횟수를 저장하고,
-- 0이 나온 횟수 / 전체 횟수, 1이 나온 횟수 / 전체 횟수 를 계산

-- 4. 몬테카를로 알고리즘을 이용한 pi의 근사값(3.141592...) 계산
-- (1) dbms_random.value() 함수를 사용해서, 2차원 좌표평면(x-y) 위의 점의 좌표 (x, y)를 무작위로 만듦.
-- 단, 0 <= x < 1, 0 <= y < 1
-- (2) x ** 2 + y ** 2 < 1을 만족하면 v_hit 변수의 값을 1 증가
-- (3) (1), (2)의 과정을 1000번 반복
-- (3) (v_hit / 1000) * 4를 계산한 값을 출력
-- (4) 4-4 실험을 1000번 반복하고 평균을 구하자



  • 정답


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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
--EX
--1
SET SERVEROUTPUT ON;
begin
    for j in 2..9 loop    
        for i in 1..9 loop
            DBMS_OUTPUT.PUT_LINE (j||' x '|| i || ' = ' || j*i);
        end loop;
        DBMS_OUTPUT.PUT_LINE ('--------------------------');
    end loop;
end;
/
 
declare
    v_x number := 1;
    v_y number := 2;
begin
    loop
        v_x := 1;
        loop
            DBMS_OUTPUT.PUT_LINE (v_y || ' x '|| v_x || ' = ' || (v_y*v_x));
            exit when v_x=9;
             v_x := v_x+1;
        end loop;
        v_y := v_y+1;
        DBMS_OUTPUT.PUT_LINE ('--------------------------------------------------');
        exit when v_y=10;
    end loop;
end;
/
 
declare
    v_x number := 1;
    v_y number := 2;
begin
    while v_y <= 9 loop
            v_x := 1;
            DBMS_OUTPUT.PUT_LINE (v_y || ' 단 ');
            while v_x<=9 loop
                DBMS_OUTPUT.PUT_LINE (v_y || ' x '|| v_x || ' = ' || (v_y*v_x));
                v_x := v_x+1;
                
            end loop;
                DBMS_OUTPUT.PUT_LINE ('--------------------------------------------------');
            v_y := v_y+1;
       
    end loop;
    
end;
/
 
DECLARE
    i number    := 2;
    j number    := 1;
    
BEGIN
    while i<10 loop  
        while j<10 loop
            j   := j+1;
            DBMS_OUTPUT.PUT_LINE (i||' x '|| j || ' = ' || j*i);
        end loop;
        i   :=  i+1;
    end loop;
 
END;
/
--2
begin
    for j in 2..9 loop    
        for i in 1..j loop
            DBMS_OUTPUT.PUT_LINE (j||' x '|| i || ' = ' || j*i);
        end loop;
        DBMS_OUTPUT.PUT_LINE ('--------------------------');
    end loop;
end;
/
--2------------------------------
declare
    v_x number := 1;
    v_y number := 2;
begin
    loop
        v_x := 1;
        loop
            DBMS_OUTPUT.PUT_LINE (v_y || ' x '|| v_x || ' = ' || (v_y*v_x));
            exit when v_x=v_y;
             v_x := v_x+1;
        end loop;
        v_y := v_y+1;
        DBMS_OUTPUT.PUT_LINE ('--------------------------------------------------');
        exit when v_y=10;
    end loop;
end;
/
 
declare
    v_x number := 1;
    v_y number := 2;
begin
    while v_y <= 9 loop
            v_x := 1;
            while v_x<=9 loop
                DBMS_OUTPUT.PUT_LINE (v_y || ' x '|| v_x || ' = ' || (v_y*v_x));
                v_x := v_x+1;
                exit when v_x=v_y+1;
            end loop;
                DBMS_OUTPUT.PUT_LINE ('--------------------------------------------------');
            v_y := v_y+1;
        exit when v_y>9;
    end loop;
    
end;
/
--2--------------------------------------
 
 
 
 
 
 
 
 
--3
--(3-1)
declare
    v_rn number;
begin
select trunc(dbms_random.value(0,2)) into v_rn from dual;
DBMS_OUTPUT.PUT_LINE(v_rn);
end;
/
--(3-2)
declare
    v_rn number;
begin
    select trunc(dbms_random.value(0,2)) into v_rn from dual;
    if v_rn = 0 then
        DBMS_OUTPUT.PUT_LINE('head');
    else
        DBMS_OUTPUT.PUT_LINE('tail');
    end if;
        
end;
/
--(3-3)--------------------------------------------------------------
declare
    v_rn number;
    v_x  number := 0;
begin
    for i in 1..1000 loop
        select trunc(dbms_random.value(0,2)) into v_rn from dual;
        if v_rn = 1 then
            v_x := v_x+1;
        end if;
    end loop;
    DBMS_OUTPUT.PUT_LINE('0이 나온 횟수 : '|| (1000-v_x));
    DBMS_OUTPUT.PUT_LINE('1이 나온 횟수 : '|| v_x);
    DBMS_OUTPUT.PUT_LINE('1이 나온 횟수/전체 횟수 : '|| v_x/1000);
    
end;
/
 
--(3-3-2)--------------------------------------------------------------
declare
    v_rn number;
    v_x  number := 0;
    i    number :=1;
begin
    loop
        select trunc(dbms_random.value(0,2)) into v_rn from dual;
        if v_rn = 1 then
            v_x := v_x+1;
        end if;
        i:=i+1;
    exit when i = 1000;
    end loop;
    DBMS_OUTPUT.PUT_LINE('0이 나온 횟수 : '|| (1000-v_x));
    DBMS_OUTPUT.PUT_LINE('1이 나온 횟수 : '|| v_x);
    DBMS_OUTPUT.PUT_LINE('1이 나온 횟수/전체 횟수 : '|| v_x/1000);
    
end;
/
--(3-3-3)--------------------------------------------------------------
declare
    v_rn number;
    v_x  number := 0;
    i    number :=1;
begin
    while i<=1000 loop
        select trunc(dbms_random.value(0,2)) into v_rn from dual;
        if v_rn = 1 then
            v_x := v_x+1;
        end if;
        i:=i+1;   
    end loop;
    DBMS_OUTPUT.PUT_LINE('0이 나온 횟수 : '|| (1000-v_x));
    DBMS_OUTPUT.PUT_LINE('1이 나온 횟수 : '|| v_x);
    DBMS_OUTPUT.PUT_LINE('1이 나온 횟수/전체 횟수 : '|| v_x/1000);
    
end;
/
 
 
--4 -1---------------------------
DECLARE
    v_x number;
    v_y number;
BEGIN
 
select dbms_random.value(01),dbms_random.value(01)
into v_x, v_y           from dual;
DBMS_OUTPUT.PUT_LINE('무작위 좌표 : ('|| v_x||','||v_y||')' );
END;
/
--4-2
DECLARE
    v_x number;
    v_y number;
    v_hit number := 0;
BEGIN
    select  power(dbms_random.value(01),2),
            power(dbms_random.value(01),2)
    into v_x, v_y           from dual;
 
    if (v_x+v_y)<1 then
        v_hit := v_hit+1;
    end if;
 
DBMS_OUTPUT.PUT_LINE('v_hit : '|| v_hit );
END;
/
 
--4-3
DECLARE
    v_x number;
    v_y number;
    v_hit number := 0;
BEGIN
 
    for i in 1..1000 loop
        select  power(dbms_random.value(01),2),
                power(dbms_random.value(01),2)
        into v_x, v_y           from dual;
    
        if (v_x+v_y)<1 then
            v_hit := v_hit+1;
        end if;
    
    end loop;
DBMS_OUTPUT.PUT_LINE('v_hit : '|| v_hit );
DBMS_OUTPUT.PUT_LINE('(v_hit/1000)*4 : '|| (v_hit/1000)*4 );
END;
/
 
--      4-4 실험을 1000번 반복하고 평균을 구하자
 
 
DECLARE
    v_x number;
    v_y number;
    v_hit number := 0;
    v_sum number := 0;
BEGIN
    for i in 1..100 loop
        v_hit := 0;
        for i in 1..1000 loop
            select  power(dbms_random.value(01),2),
                    power(dbms_random.value(01),2)
            into v_x, v_y           from dual;
        
            if (v_x+v_y)<1 then
                v_hit := v_hit+1;
            end if;
        end loop;
        v_sum := v_sum + ((v_hit/1000)*4);
    end loop;
DBMS_OUTPUT.PUT_LINE('v_avg : '|| v_sum/1000 );
 
END;
/
cs