2020牛客国庆集训派对day4 Jokewithpermutation

Jokewithpermutation

题目描述

Joey had saved a permutation of integers from 1 to n in a text file.
All the numbers were written as decimal numbers without leading
spaces. Then Joe made a practical joke on her: he removed all the
spaces in the file. Help Joey to restore the original permutation
after the Joe’s joke! 输入描述: The input file contains a single line with
a single string — the Joey’s permutation without spaces. The Joey’s
permutation had at least 1 and at most 50 numbers. 输出描述: Write a line
to the output file with the restored permutation. Don’t forget the
spaces! If there are several possible original permutations, write any
one of them.

示例1
输入
复制

4111109876532

输出
复制

4 1 11 10 9 8 7 6 5 3 2

备注:
Author: Mikhail Dvorkin

题意:

给你一串数,这串数字为n的全排列,问怎么将数分段格,使得成为n的全排列
看样例4111109876532,可以为4 1 11 10 9 8 7 6 5 3 2

题解:

队友做得,dfs暴力即可,就是假设当为一位数或者两位数时,看看情况
详细看代码吧

代码:

#include<bits/stdc++.h>
#define maxn 6000
using namespace std;
char a[maxn];
vector<int>ans;
bool vis[maxn];
unordered_map<int,int>p;
bool f=0;
int s;
void dfs(int n){if(f)return ;int size=strlen(a+1);if(n>size){printf("%d",ans[0]);for(int i=1;i<ans.size();i++){printf(" %d",ans[i]);}f=1;return ;}if(p[a[n]-'0']==0){p[a[n]-'0']=1;ans.push_back(a[n]-'0');dfs(n+1);ans.pop_back();p[a[n]-'0']=0;}if(f)return ;if(n<=size-1&&p[(a[n]-'0')*10+(a[n+1]-'0')]==0&&(a[n]-'0')*10+(a[n+1]-'0')<=s){p[(a[n]-'0')*10+(a[n+1]-'0')]=1;ans.push_back((a[n]-'0')*10+(a[n+1]-'0'));dfs(n+2);ans.pop_back();p[(a[n]-'0')*10+(a[n+1]-'0')]=0;}if(f)return ;
}
int main(){scanf("%s",a+1);s=strlen(a+1)>9?(strlen(a+1)-9)/2+9:strlen(a+1);dfs(1);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319227.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.NET Core使用IO合并技巧轻松实现千万级消息推送

之前讲述过多路复用实现单服百万级别RPS吞吐,但在文中有一点是没有说的就是消息IO合并&#xff0c;如果缺少了消息IO合并即使怎样多路复用也很难达到百万级别的请求响毕竟所有应用层面的网络IO读写都是非常损耗性能的&#xff08;需要硬件配置很高的服务器&#xff09;。这一章…

codeforces1457 C. Bouncing Ball

写这个题写了1h&#xff0c;赛后无意看见jly神的代码只能膜拜%%% C. Bouncing Ball 预处理从1→k1\to k1→k开始跳需要添加多少个平台&#xff0c;预处从k1→nk1\to nk1→n这些不难发现由于每次跳k格&#xff0c;只需要利用前缀和思想和前面预处理的结果即可做差求出。 然后枚…

P4491-[HAOI2018]染色【二项式反演,NTT】

正题 题目链接:https://www.luogu.com.cn/problem/P4491 题目大意 给nnn个物品染上mmm种颜色&#xff0c;若恰好有kkk个颜色的物品个数为SSS那么就会产生WkW_kWk​的贡献。求所有染色方案的贡献和 1≤n≤107,1≤m≤105,1≤S≤1501\leq n\leq 10^7,1\leq m\leq 10^5,1\leq S\l…

【传递闭包】【倍增】幸福路径(P4308)

正题 P4308 题目大意 给一个图&#xff0c;每个点有一个权值 axa_xax​&#xff0c;当你经过一条边时体力p\times pp&#xff08;体力初始为1&#xff09;&#xff0c;每到一个点造成的贡献为体力ax\times a_xax​&#xff0c;问最大贡献&#xff08;路径可能是无限长的&…

天气情况图像分类练习赛 第三阶段(赛中感)

第三阶段也是实战阶段&#xff0c;不同于前两个阶段的填空而是实打实的预测分析 题目会给出8000张照片数据&#xff0c;其中6000作为训练集而另外2000张作位测试集&#xff0c;通过对6000张的训练来预测2000的结果&#xff0c;并将结果输出到csv文件中&#xff0c;提交检验成功…

一码阻塞,万码等待:ASP.NET Core 同步方法调用异步方法“死锁”的真相

在我们 2015 年开始的从 .NET Framework 向 .NET Core 迁移的工程中&#xff0c;遇到的最大的坑就是标题中所说的——同步方法中调用异步方法发生”死锁”。虽然在 .NET Framework 时代就知道不能在同步方法中调用异步方法&#xff0c;但我们却明知路有坑&#xff0c;偏向此路行…

codeforces1456 D. XOR-gun

D. XOR-gun 大佬题解 当n比较大的时候&#xff0c;一定有连续相同的3个数最高位都是1&#xff0c;只需要将这三个数其中两个异或一次即可满足题意只需要操作1次。 当n比较小时可以直接暴力&#xff0c;不难发现异或操作要么是一段区间异或然后与区间端点相邻的比较O(n2)O(n^2…

AT4119-[ARC096C]Everything on It【斯特林数,容斥】

正题 题目链接:https://www.luogu.com.cn/problem/AT4119 题目大意 一个集合S{k∈[1,n]∪N}S\{k\in[1,n]\cup N\}S{k∈[1,n]∪N}&#xff0c;它的所有子集作为元素组成的集合中要求满足每一个数字的出现之和不小于222&#xff0c;求方案数对PPP取模。 1≤n≤3000,P∈[108,109…

【交互】【随机】Lost Root(CF1061F)

正题 luogu CF1061F 题目大意 给出n和k&#xff0c;现在有一颗n个点的满k叉树&#xff0c;每次查询可以问一个点是否在另外两个点的路径上&#xff0c;让你在 60n60\times n60n 次询问内得到根节点 解题思路 因为是满k叉数&#xff0c;可以先得到深度dep 每次随机找两个点&…

take

take 题解参考 题目描述 Kanade has n boxes , the i-th box has p[i] probability to have an diamond of d[i] size. At the beginning , Kanade has a diamond of 0 size. She will open the boxes from 1-st to n-th. When she open a box,if there is a diamond in it an…

将传统 ASP.NET 应用迁移到 .NET Core

点击蓝字关注我现在越来越多的人在谈论. NET Core。诚然&#xff0c;.NET Core 是未来, 但是.NET Framework 仍在支持, 因为大量的应用程序无法在短时间内迁移。.NET Core 和 .NET Framework 就像电动汽车和汽油动力汽车。汽油车是成熟的&#xff0c;你可以毫无任何问题驾驶它&…

CF932G-Palindrome Partition【PAM】

正题 题目链接:https://www.luogu.com.cn/problem/CF932G 题目大意 给出一个长度为nnn的字符串&#xff0c;将其分为kkk段&#xff08;kkk为任意偶数&#xff09;&#xff0c;记为ppp。要求满足对于任意iii都有pipk−i1p_ip_{k-i1}pi​pk−i1​。求方案数。 1≤n≤1061\leq n…

2018 ACM ICPC Asia Regional - Seoul B.Cosmetic Survey

参考大佬代码 题目大意 nnn个顾客&#xff0c;mmm种画妆品&#xff0c;每一个顾客会给mmm种化妆品一个值&#xff0c;这个值代表这个化妆品在他心中的排名&#xff0c;排名越小越喜欢&#xff0c;如果这个值为0说明最不喜欢这一种化妆品&#xff08;值为0理解为无穷大&#xf…

The table(CF226D)

正题 CF226D 题目大意 给一个n*m的矩阵&#xff0c;每次操作可以使一行或一列全部变号&#xff08;变-&#xff0c;-变&#xff09;&#xff0c;问如何操作可以使所有行列之和都是正数 解题思路 考虑每次暴力找小于0的一行或一列&#xff0c;然后反转 因为每次反转肯定会使…

[翻译] 初看 ASP.NET Core 3.0 即将到来的变化

原文: A first look at changes coming in ASP.NET Core 3.0在我们努力完成下一个 minor 版本的 ASP.NET Core 的同时&#xff0c;我们也在对下一个 major 版本进行更新&#xff0c;其中包括如何使用框架组合项目、更紧密的 .NET Core 集成以及第三方开源集成&#xff0c;所有这…

数字串

来源&#xff1a;牛客网&#xff1a; 题目描述 一个只含数字的字符串&#xff0c;q次操作&#xff0c;每次操作将第i位数字改为x&#xff0c;每次操作后&#xff0c;统计长度在[l, r]之间且首数字大于尾数字的子串的个数。 输入描述: 第一行一个只含数字的字符串&#xff1b…

【随机】Kuroni and the Punishment(CF1305F)

正题 luogu CF1305F 题目大意 给你n个数&#xff0c;每次操作可以使一个数1或-1&#xff0c;让你用最小的操作数使所有数的gcd>1 解题思路 显然把所有数都修改为偶数可以得到 2|gcd&#xff0c;且步数 ≤n\leq n≤n 对于其它方案&#xff0c;至少有一半的数修改次数小于…

hdu5909-Tree Cutting【FWT】

正题 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid5909 题目大意 给出nnn和mmm&#xff08;m2km2^km2k&#xff09;。再给出一个大小为nnn的树&#xff0c;每个点有点权&#xff0c;对于每个i∈[1,m)i\in[1,m)i∈[1,m)求有多少个联通子图的点权异或和为iii 1≤T≤10…

codeforces1455 D. Sequence and Swaps

昨天晚上巨困&#xff0c;就没有打&#xff0c;今天课间的时候就看了一下D题&#xff0c;发现好像可以瞎搞&#xff0c;于是吃完饭就写了一下&#xff0c;调过样例一次就A了qaq。 D. Sequence and Swaps 枚举贪心 由于数据范围n≤500n\leq500n≤500&#xff0c;由此我们可以在…

珂朵莉的数列

来源&#xff1a;牛客网&#xff1a; 题目描述 珂朵莉给了你一个序列&#xff0c;有n(n1)/2 ​ 个子区间&#xff0c;求出她们各自的逆序对个数&#xff0c;然后加起来输出 输入描述: 第一行一个数 n 表示这个序列 a 的长度 之后一行 n 个数&#xff0c;第i个数表示ai 输出…