六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 166|回复: 0

求某数为几个2的N次方组成的函数(递归法,循环法)

[复制链接]

升级  36.35%

563

主题

563

主题

563

主题

探花

Rank: 6Rank: 6

积分
1727
 楼主| 发表于 2013-2-7 20:38:27 | 显示全部楼层 |阅读模式
--递归法
create function f_getnum(@i int)
returns @t table(r int)
as
begin
declare @n int
set @n = 1
while [email=2*@n<=@i]2*@n<=@i[/email]
begin
set @n = @n * 2
end
insert @t select @n
set @n = @i - @n
if @n > 0
insert @t select r from f_getnum(@n)
return;
end
go
select * from f_getnum(10)
--循环法
alter function f_getnum (@i int)
returns @t table(r int)
as
begin
declare @n int
while @i > 0
begin
set @n = 1
while [email=2*@n<=@i]2*@n<=@i[/email]
begin
set @n = @n * 2
end
insert @t select @n
set @i = @i - @n
end
return;
end
go
select * from f_getnum(10)
/*
r
-----------
8
2
(2 行受影响)
*/

http://topic.csdn.net/u/20090807/08/19f980a3-3830-4261-90ca-0f85ec628492.html?72858
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表