码迷,mamicode.com
首页 > Web开发 > 详细

JSK424:置换的玩笑(搜索)

时间:2017-04-07 13:38:05      阅读:195      评论:0      收藏:0      [点我收藏+]

标签:ide   closed   pre   har   ret   main   open   next   删掉   

小蒜头又调皮了。这一次,姐姐的实验报告惨遭毒手。

姐姐的实验报告上原本记录着从 1 到 n 的序列,任意两个数字间用空格间隔。但是“坑姐”的蒜头居然把数字间的空格都给删掉了,整个数字序列变成一个长度为 1 到 100 的且首部没有空格的数字串。

现在姐姐已经怒了,蒜头找你写个程序快点把试验数据复原。

输入

输入文件有一行,为一个字符串——被蒜头搞乱的实验数据。

字符串的长度在 1 到 100 之间。

输出

输出共一行,为姐姐的原始测试数据—— 1 到 n 的输出。

任意两个数据之间有一个空格。

如果有多组符合要求的正确解,输出其中任意一组即可。

样例输入

4111109876532

样例输出

4 1 11 10 9 8 7 6 5 3 2

Solve:

蜜汁DFS,考虑的东西有点多,但是反正就是个生成全排列啦,就是1~n内的每个数都出现且只出现一次,当然这个n也是在搜完之后才找出来了

Code:

技术分享
 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 char data[666] = {\0};
 4 bool vis[666] = {0};
 5 int ans[666] = {0};
 6 int len = 0;
 7 bool flag = 0;
 8 int ml;
 9 void Dfs(int pos , int num)
10 {
11     if(flag)
12         return ;
13     if(pos >= len)
14     {
15         int chu[110] = {0};
16         int mx = -1;
17         for(int i = 0 ; i < num ; ++i)
18         {
19             mx = max(mx , ans[i]);
20             chu[ans[i]] = 1;
21         }
22         bool gao = 1;
23         for(int i = 1 ; i <= mx ; ++i)
24         {
25             if(!chu[i])
26             {
27                 gao = 0;
28                 break;
29             }
30         }
31         if(gao)
32         {
33             for(int i = 0 ; i < num ; ++i)
34                 printf("%d " , ans[i]);
35             printf("\n");
36             flag = 1;
37         }
38         return ;
39     }
40     int next = data[pos] - 48;
41     if(!vis[next])
42     {
43         vis[next] = 1;
44         ans[num] = next;
45         Dfs(pos + 1 , num + 1);
46         vis[next] = 0;
47     }
48     if(pos + 1 < len)
49     {
50         next = (data[pos] - 48) * 10 + (data[pos + 1] - 48);
51         if(!vis[next])
52         {
53             vis[next] = 1;
54             ans[num] = next;
55             Dfs(pos + 2 , num + 1);
56             vis[next] = 0;
57         }
58     }
59     return;
60 }
61 int main()
62 {
63     scanf(" %s" , data);
64     len = strlen(data);
65     Dfs(0 , 0);
66 }
View Code

 

JSK424:置换的玩笑(搜索)

标签:ide   closed   pre   har   ret   main   open   next   删掉   

原文地址:http://www.cnblogs.com/jianglingxin/p/6677589.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!