oracle怎么求素数 素数和怎么求

输出100~300之间的素数,每行显示6个数,用oracle 中plsql求解

declare

成都创新互联是专业的沈丘网站建设公司,沈丘接单;提供网站建设、做网站,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行沈丘网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!

b boolean;

c number(4):=1;

begin

for a in 100..300 loop

b:=true;

for i in 2..sqrt(a) loop

if mod(a,i)=0 then

b:=false;

end if;

end loop;

if b=true then

if mod(c,6)0 then

dbms_output.put(a||' ');

else

dbms_output.put_line(a);

end if;

c:=c+1;

end if;

end loop;

dbms_output.new_line();

end;

【oracle】定义一个Oracle存储过程,输出1~100之间的素数。

declare

v_num number;

v_now number;

v_yes number;

c_max number;

begin

v_num:=1;

c_max:=200;--这里设置最大数,想要100这内就写100,想要1000之内就写1000

loop

v_now:=2;--这里设置每一个数的初始被除数,从2开始

v_yes:=1;--设置初始参考数,1为素数,0为非素数,默认初始为1

if v_num4 then

dbms_output.put_line(v_num);--1到3都是素数,这里就不再判断了

-- v_num:=v_num+1;--自增1

end if;

if v_num=4 then

--这里开始判断,只能被1和本身整除的数,就是素数

loop

if mod(v_num,v_now)=0 and v_numv_now then --如果有能被整除的数,且被除数不是除数本身,就不是素数

v_yes:=0;

end if;

v_now:=v_now+1;--被除数递增

exit when v_now=v_num;--当被除数大于除数时退出

end loop;--因为要一个一个的判断,所以要来一次循环

end if;

if v_num4 and v_yes=1 then

dbms_output.put_line(v_num);

-- v_num:=v_num+1;--自增

end if;

v_num:=v_num+1;--自增

exit when v_num=c_max;

end loop;

end;

参考一下,自己写的

oracle怎么求1..1000之间的素数

Oracle是数据库,存储数据用的,应用逻辑最好放在数据库外面,虽然可以实现,但是并不提倡。

set serverout on

DECLARE

v_i   NUMBER;

v_j   NUMBER;

v_cnt NUMBER;

TYPE type_array IS TABLE OF NUMBER;

primes type_array;

flag   NUMBER;

BEGIN

primes := type_array();

primes.extend;

primes(1) := 2;

primes.extend;

primes(2) := 3;

v_i := 5;

v_cnt := 2;

LOOP

EXIT WHEN v_i  1000;

flag := 1;

v_j  := 1;

LOOP

EXIT WHEN primes(v_j) * primes(v_j)  v_i;

IF MOD(v_i, primes(v_j)) = 0 THEN

flag := 0;

EXIT;

END IF;

v_j := v_j + 1;

END LOOP;

IF flag = 1 THEN

primes.extend;

v_cnt := v_cnt + 1;

primes(v_cnt) := v_i;

dbms_output.put_line(v_i);

END IF;

v_i := v_i + 2;

END LOOP;

END;

/

用 oracle中PL/SQL算法 求100内的素数

本过程输入参数inp,计算1到inp之间的素数

算法:

拿出1-inp之间的每个数i,用2到i的平方根之间的每个数去除,全部除不尽的即为素数,有一个能除尽的为非素数

set serverout on

create or replace procedure is_prime(inp number)

as

i number;

j number;

is_prim boolean;

begin

dbms_output.new_line;

dbms_output.put(to_char(2)||' ');

for i in 3..inp loop

begin

is_prim:=true;

for j in 2..trunc(sqrt(i)) loop

if mod(i,j)=0 then

begin

is_prim:=false;

exit;

end;

end if;

end loop;

if is_prim then dbms_output.put(to_char(i)||' '); end if;

end;

end loop;

dbms_output.new_line;

end;

/

exec is_prime(100)

Oracle中怎样使用pl/sql计算出1--100以内的素数啊

--创建中间表

create table t_1 (

num number(6));

--1--100数据写到中间表

begin

for r1 in 1..100 loop

insert into t_1 (num) values (r1);

commit ;

end loop ;

end ;

--结果

select *

from t_1 t

where not exists (select *

from t_1 a, t_1 b

where a.num * b.num = t.num

and a.num 1

and b.num 1)

order by 1 ;

oracle for循环求1到100之间的素数

declare

/*思路:素数是只能被1和它本身整除的数,针对一个数n,从2到n-1对其求模,如果能整除就不是素数*/

v_result number; /*是否为素数,1为素数,0为非素数*/

j number; /*从2到i-1取模,如果能被整除就不是素数*/

begin

for i in 1 .. 100 loop

j := 2;

v_result := 1;

loop

if mod(i, j) = 0 and i j then

v_result := 0;

end if;

j := j + 1;

exit when j = i;

end loop;

if v_result = 1 then

dbms_output.put_line(i);

end if;

end loop;

end;


本文名称:oracle怎么求素数 素数和怎么求
标题URL:http://scyanting.com/article/hhshjd.html