c 语言math.pow,cmath中的pow函数

我晕了~~还不行.....................

我把我的代码帖上来吧~~~

[CODE]

/*---------------------------------------------------------------

Description

集合的前N个元素:编一个程序,按递增次序生成集合M的最小的N个数,M的定义如下:

(1)数1属于M;

(2)如果X属于M,则Y=2*X+1和Z=3*x+1也属于M;

(3)此外再没有别的数属于M。

Input

n(b.in) (1≤n≤100)

Output

生成集合M的最小的N个数(b.out)

Sample Input

4

Sample Output

1 3 4 7

-----------------------------------------------------------------*/

#include

#include

#include

#include

using namespace std;

int main()

{

int num, i, j, k;

cin>>num;

int sum=0;

for( i=0; num > sum; i++ )

sum = sum + pow(2.0,double(i));

k=i-1;

int *p=new int [pow(2.0,double(k))];

vector< int > vec;

p[0]=1, vec.push_back(1);

for( i=1; i<=k; i++ )

{

for( j=pow(2,i)-1; j>=0; j--)

{

if( j % 2 !=0 )

p[j] = 3 * p[j/2] + 1;

else

p[j] = 2 * p[j/2] + 1;

vec.push_back( p[j] );

}

}

sort( vec.begin(), vec.end() );

for( i=0; i

cout<

cout<

return 0;

}

[/CODE]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值