【♂Not The Triumph♂O(∩_∩)O哈哈~But The Struggle♂】

竞赛决不是捷径,它只是另一种艰辛的生活方式。得到与失去,只有时间会去评判;成功与失败,只有历史能去仲裁。我不会永远成功,正如我不会永远失败一样

  C++博客 :: 首页 :: 联系 ::  :: 管理
  6 Posts :: 239 Stories :: 25 Comments :: 0 Trackbacks

常用链接

留言簿(7)

我参与的团队

搜索

  •  

积分与排名

  • 积分 - 108450
  • 排名 - 229

最新评论

阅读排行榜

评论排行榜

请考虑一个由1到N(N=3, 4, 5 ... 9)的数字组成的递增数列:1 2 3 ... N。现在请在数列中插入“+”表示加,或者“-”表示减,乘是“ ”表示空白(例如1-2 3就等于1-23),来将每一对数字组合在一起(请不在第一个数字前插入符号)。计算该表达式的结果并判断其值是否为0。请你写一个程序找出所有产生和为零的长度为N的数列。

格式
PROGRAM NAME: zerosum

INPUT FORMAT
单独的一行表示整数N (3 <= N <= 9)。

OUTPUT FORMAT
按照ASCII码的顺序,输出所有在每对数字间插入“+”, “-”, 或 “ ”后能得到和为零的数列。

SAMPLE INPUT (file zerosum.in)
7

SAMPLE OUTPUT (file zerosum.out)
1+2-3+4-5-6+7
1+2-3-4+5+6-7
1-2 3+4+5+6+7
1-2 3-4 5+6 7
1-2+3+4-5+6-7
1-2-3-4-5+6+7

【参考程序】:

/*
ID: XIONGNA1
PROG: zerosum
LANG: C++
*/
#include
<iostream>
#include
<cstring>
using namespace std;
char ch[10];
int n;
void work()
{
    
int sum=0,p=1,k=1,t;
    
while (p<=n)
    {
        t
=0;
        
while (ch[p]==' ')
        {
            t
=t*10+p; p++;
        }
        t
=t*10+p;
        sum
+=t*k;
        
if (ch[p]=='+') k=1;
        
else k=-1;
        p
++;
    }
    
if (sum==0)
    {
        
for (int i=1;i<=n-1;i++) printf("%d%c",i,ch[i]);
        printf(
"%d\n",n);
    }
}
void dfs(int dep)
{
    
if (dep==n)
    {
        work(); 
return ;
    }
    ch[dep]
=' '; dfs(dep+1);
    ch[dep]
='+'; dfs(dep+1);
    ch[dep]
='-'; dfs(dep+1);
}
int main()
{
    freopen(
"zerosum.in","r",stdin);
    freopen(
"zerosum.out","w",stdout);
    scanf(
"%d",&n);
    dfs(
1);
    
return 0;
}
posted on 2009-07-20 11:07 开拓者 阅读(236) 评论(0)  编辑 收藏 引用 所属分类: USACO 题解

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理