数字子集的和排序

设集合T是所有3的幂集,即T={13927……},现对T的所有子集的元素数值和排序,排在第n位的集合是什么?

 

输入(请使用标准输入、输入,不要读写文件)

输入数据只有一个正整数n1n4,000,000,000

输出(请使用标准输入、输入,不要读写文件)

按递增顺序,输出集合的元素,每行输出一个元素。

 

样例输入1

样例输出1

样例输入2

样例输出2

5

9

50

1

81

243

 

 

#include<stdio.h>

#include<math.h>

main()

{

       unsigned long  n = 0,t = 0,k = 0;

       double c[100];

       printf("请输入一个正整数n(1<n<=4000000000)/n");

      

       scanf("%ld",&n);

       //单独的第k个元素排在2(k-1)次幂 1的位置

       //1-2 3-39-527-9,……

      

       do

       {

              t=(long)(log10(n - 1)/log10(2)) + 1; //求子集中最大的元素在集合T中的位置

              c[k++]=pow(3,t-1); //t个元素为3(t-1)次幂

              n=n-pow(2,t-1);

             

       }while(n>1);//1位永远是空集,所以条件要大于1

      

       for(int i=k-1;i>=0;i--)

              printf("%1.lf/n",c[i]);

      

}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值