天平砝码称重量

源blog地址http://onlywish.me

用天平称重量

有1,3,9,27,81的砝码

输入一个121以内的数。求出称重方法:

如:输入10 显示 9+1;

输入 7  显示 9-3+1;

下面是答案(自己写的,非标准):

 

#include <stdio.h>
#include <math.h>
int sum = 0;
 int array[5] = {1,3,9,27,81};
 int count[5] = {1,4,13,40,121};
 char jo[2][2] = {
     {‘+’,’-’},
     {‘-’,’+’}
     };

void digui(int,int);

void main()
{
 int num;
 //scanf("%d",&num);
 for(int i = 1 ; i < 122 ; i++)
 {
  printf("%d = ",i);
  digui(i,0);
 }

}
void digui(int num,int j)
{

 for(int i  = 0 ; i<5 ; i++)
  if(num <= count[i]) break; //定位
  if(num > array[i])
  {
   printf("%d%c",array[i],jo[j][0]);
   if(j == 1) j = (j+1)%2;
   digui(fabs(num-array[i]),j);
  }
  if(num < array[i])
  {
   printf("%d%c",array[i],jo[j][1]);
   if(j ==0) j = (j+1)%2;
   digui(fabs(num-array[i]),j);
  }
  if(num == array[i])
  {
   printf("%d\n",array[i]);
   return;
  }

 

转载于:https://www.cnblogs.com/onlywish/p/4189037.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值