程序设计方法作业06

本文介绍了一种将正整数转换为其组成2的幂次方的表示方法,通过递归算法实现,例如将数字137表示为2(7)+2(3)+2(0)。提供了具体的实现代码,展示了如何将任意正整数n(n≤20000)转换为这种形式。

题目1:将非负十进制整数n转换成b进制。(其中b=2~16)
题目2:任何一个正整数都可以用2的幂次方表示。例如:
    137=27+23+2^0    
同时约定幂次方用括号来表示,即ab 可表示为a(b)。
   由此可知,137可表示为:
     2(7)+2(3)+2(0)
进一步:7= 22+2+20 (21用2表示)
     3=2+2^0
所以最后137可表示为:
     2(2(2)+2+2(0))+2(2+2(0))+2(0)
   又如:
     1315=2^10 +2^8 +2^5 +2+2^0
所以1315最后可表示为:
   2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0)
  输入:正整数(n≤20000)
输出:符合约定的n的0,2表示(在表示中不能有空格)
输入格式 Input Format
一个正整数
输出格式 Output Format
符合约定的n的0,2表示(在表示中不能有空格)
样例输入 Sample Input
73
样例输出 Sample Output
2(2(2)+2)+2(2+2(0))+2(0)

#include <stdio.h>
void transFormation(int n ,int b)
{   
	char t;
    if(n==0){
	   return ;
	}
	else{
	   transFormation(n/b,b);
	   if(n%b<10){
		  printf("%d",n%b);
	   }
	   else{
	      t='A'+n%b-10;
		  printf("%c",t);
	   }
	}
}

int main (void)
{
   int n ,b;
   printf("输入n的值:");
   scanf("%d",&n);
   printf("输入b的值:");
   scanf("%d",&b);
   transFormation(n,b);
   printf("\n");
   return 0;
}
	#include <stdio.h>
	void fun (int x,int flag)
	{
	   int n=0,t=1;
	   if(flag==1&&x){
		  printf("+");
	   }
	   if(x==0){
		  return ;
	   }
	   if(x==1){
		  printf("2(0)");
		  return;
	   }
	   if(x==2){
		  printf("2");
		  return ;
	   }
	   printf("2");
	   if(x>=4){
		printf("(");
	   }
	   while(t<=x){
		  t=t*2;
		  n++;
	   }
	   if(n-1>=2){
		fun(n-1,0);
	   }
	   if(x>=4){
		printf(")");
	   }
	   fun(x-t/2,1);
	}
	int main (void)
	{
	  int x;
	  scanf("%d",&x);
	  fun (x,0);
	  printf("\n");
	  return 0;
	}		
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值