poj1416

简单题

ContractedBlock.gif ExpandedBlockStart.gif View Code
 
   
#include < iostream >
#include
< cstdio >
#include
< cstdlib >
#include
< cstring >
using namespace std;

int n, m, a[ 10 ], la, ans;
bool reject;
bool split[ 10 ], ansplit[ 10 ];

void work()
{
la
= 0 ;
while (n > 0 )
{
a[la]
= n % 10 ;
n
/= 10 ;
la
++ ;
}
for ( int i = 0 ; i < la / 2 ; i ++ )
swap(a[i], a[la
- i - 1 ]);
}

void dfs( int pos, int sum, int d)
{
if (sum + d > m)
return ;
if (pos == la)
{
sum
+= d;
if (ans == sum)
{
reject
= true ;
return ;
}
if (sum <= m && sum > ans)
{
reject
= false ;
ans
= sum;
for ( int i = 0 ; i < la; i ++ )
ansplit[i]
= split[i];
}
return ;
}
dfs(pos
+ 1 , sum, d * 10 + a[pos]);
split[pos]
= true ;
dfs(pos
+ 1 , sum + d, a[pos]);
split[pos]
= false ;
}

void output()
{
if (ans == - 1 )
{
printf(
" error\n " );
return ;
}
if (reject)
{
printf(
" rejected\n " );
return ;
}
printf(
" %d " , ans);
for ( int i = 0 ; i < la; i ++ )
{
if (ansplit[i])
putchar(
' ' );
printf(
" %d " , a[i]);
}
printf(
" \n " );
}

int main()
{
// freopen("t.txt", "r", stdin);
while (scanf( " %d%d " , & m, & n), n | m)
{
work();
memset(split,
0 , sizeof (split));
ans
= - 1 ;
reject
= false ;
dfs(
1 , 0 , a[ 0 ]);
output();
}
return 0 ;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值