C. Permute Digits dfs大模拟
http://codeforces.com/contest/915/problem/C
这题麻烦在前导0可以直接删除,比如
1001
100
应该输出11就好
我的做法是用dfs,每一位每一位的比较。在dfs的时候用一个char *指针指着b需要比较的位置,这样做方便很多。
2018年1月20日 16:35:51
身体好差,代码也很多不会写了。退役得真快。
bigger需要在新的一行里面弄,因为函数传参的时候不确定是哪个先,哪个后的。再正规点,不要一行写两次,带有++, --的东西
也就是不要
dfs(cmp, ++cmp)类似这样的
#include <bits/stdc++.h>
#define IOS ios::sync_with_stdio(false)
using namespace std;
#define inf (0x3f3f3f3f)
typedef long long int LL;
char str[], sub[];
int vis[];
int lenstr, lensub;
bool flag;
int cut;
vector<int> vc;
bool dfs(int cur, bool bigger, char *cmp) {
if (cur == min(lenstr - cut, lensub)) {
if (lenstr - cut > lensub) return false;
return true;
}
if (bigger) {
for (int i = ; i >= ; --i) {
if (!vis[i]) continue;
vis[i]--;
if (dfs(cur + , bigger, ++cmp)) {
vc.push_back(i);
return true;
}
vis[i]++;
}
} else {
for (int i = (*cmp) - ''; i >= ; --i) {
if (!vis[i]) continue;
vis[i]--;
bool t = bigger | (i < (*cmp) - '');
char *nex = cmp + ;
if (dfs(cur + , t, nex)) {
vc.push_back(i);
return true;
}
vis[i]++;
}
}
if (!vis[]) return false;
if (cur != ) {
vis[]--;
bigger |= (*cmp) > ''; //这里需要新的一行
if (dfs(cur + , bigger, ++cmp)) {
vc.push_back();
return true;
}
vis[]++;
return false;
} else {
if (lenstr - cut - < lensub) {
vis[]--;
cut++;
if (dfs(, true, sub)) {
return true;
}
vis[]++;
cut--;
} else {
vis[]--;
cut++;
if (dfs(, bigger, sub)) {
return true;
}
vis[]++;
cut--;
}
}
return false;
}
void work() {
LL a, b;
cin >> a >> b;
sprintf(str, "%lld", a);
sprintf(sub, "%lld", b);
if (a == b) {
printf("%lld\n", a);
return;
}
lenstr = strlen(str), lensub = strlen(sub);
if (lensub > lenstr) {
for (int i = ; i < lenstr; ++i) {
int mx = -, id = ;
for (int j = ; j < lenstr; ++j) {
if (vis[j]) continue;
if (mx < str[j] - '') {
mx = str[j] - '';
id = j;
}
}
vis[id] = true;
printf("%d", mx);
}
return;
}
for (int i = ; i < lenstr; ++i) vis[str[i] - '']++;
dfs(, false, sub);
for (int i = vc.size() - ; i >= ; --i) {
printf("%d", vc[i]);
}
} int main() {
#ifdef local
freopen("data.txt", "r", stdin);
// freopen("data.txt", "w", stdout);
#endif
work();
return ;
}
正解应该是一个贪心,经典的贪心
对于每一位,能否放x,条件是放了x后,能组成的最小的数不能大于b
公司要求用go,学了几天用go写了一发
// _Channels_ are the pipes that connect concurrent
// goroutines. You can send values into channels from one
// goroutine and receive those values into another
// goroutine. package main import "fmt"
import (
"bufio"
"os"
) // var (
// mess make(chan string, 2)
// ) func main() {
var str_a string
var str_b int64
input := bufio.NewReader(os.Stdin)
fmt.Fscan(input, &str_a)
fmt.Fscan(input, &str_b)
var cnt []int
for i := ; i < len(str_a); i++ {
cnt[str_a[i]-'']++
}
var ans int64
// fmt.Println(len(str_a))
for i := ; i < len(str_a); i++ {
for j := ; j >= ; j-- {
if cnt[j] == {
// fmt.Println(j, cnt[j])
continue
}
flag := false
t := ans
t = t *
t += int64(j)
cnt[j]-- if check(t, cnt, str_b) {
ans = t
flag = true
} else {
cnt[j]++
}
if flag {
break
}
}
}
fmt.Println(ans)
} func check(t int64, cnt []int, str_b int64) bool {
for i := ; i < ; i++ {
for cnt[i] > {
t = t *
t += int64(i)
cnt[i]--
}
}
return t <= str_b
}
C. Permute Digits dfs大模拟的更多相关文章
- cf Permute Digits(dfs)
C. Permute Digits You are given two positive integer numbers a and b. Permute (change order) of the ...
- 【CodeForces 915 C】Permute Digits(思维+模拟)
You are given two positive integer numbers a and b. Permute (change order) of the digits of a to con ...
- Codeforces 915 C. Permute Digits (dfs)
题目链接:Permute Digits 题意: 给出了两个数字a,b(<=1e18),保证a,b都不带前缀0.用a的字符重组一个数字使这个值最大且小于b.(保证这个值存在) 题解: 这题遇到了不 ...
- CodeForces-915C Permute Digits
C. Permute Digits time limit per test 1 second memory limit per test 256 megabytes input standard in ...
- ACdream 1188 Read Phone Number (字符串大模拟)
Read Phone Number Time Limit:1000MS Memory Limit:64000KB 64bit IO Format:%lld & %llu Sub ...
- 2016ACM-ICPC网络赛北京赛区 1001 (trie树牌大模拟)
[题目传送门] 1383 : The Book List 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 The history of Peking University ...
- [CSP-S模拟测试]:引子(大模拟)
题目描述 网上冲浪时,$Slavko$被冲到了水箱里,水箱由上而下竖直平面.示意图如下: 数字$i$所在的矩形代表一个编号为$i$的水箱.1号水箱为水箱中枢,有水管连出.除了$1$号水箱外,其他水箱上 ...
- HDU 5920 Ugly Problem 高精度减法大模拟 ---2016CCPC长春区域现场赛
题目链接 题意:给定一个很大的数,把他们分为数个回文数的和,分的个数不超过50个,输出个数并输出每个数,special judge. 题解:现场赛的时候很快想出来了思路,把这个数从中间分为两部分,当位 ...
- AC日记——神奇的幻方 洛谷 P2615(大模拟)
题目描述 幻方是一种很神奇的N*N矩阵:它由数字1,2,3,……,N*N构成,且每行.每列及两条对角线上的数字之和都相同. 当N为奇数时,我们可以通过以下方法构建一个幻方: 首先将1写在第一行的中间. ...
随机推荐
- try-catch-finally 规则( 异常处理语句的语法规则 )
1) 必须在 try 之后添加 catch 或 finally 块.try 块后可同时接 catch 和 finally 块,但至少有一个块. 2) 必须遵循块顺序:若代码同时使用 catch 和 ...
- C#去边框以及无边框窗体移动
1.去边框 : 1) 选中要去除边框的窗体,按F4调出窗体属性. 2)在属性框中找到FormBorderStyle选择none. 2.去掉边框后实现对窗口程序的拖动 1)双击窗体,进入程序设计界面 ...
- 在Repeater控件的OnItemDataBound获取数据源记录总数
Insus.NEt曾经有写过一篇<Repeater控件最后一笔记录高亮显示> ,它的实现是先宣告一个页面级的变量,然后在Data_Binding()方法内获取数据源的记录总数. 本篇是的重 ...
- [Windows] VS打开资源文件(.rc)时显示 error RC2247 : SYMBOL name too long
源解决方案:error RC2247 : SYMBOL name too long 解决方法: 将所有要包含的文件用 APSTUDIO_HIDDEN_SYMBOLS 宏包起来,保存后关闭当前的资源文件 ...
- SingleClass单例类
前言 对于一个单例类,无论初始化单例对象多少次,在程序的整个生命周期内,只会创建一个类的实例对象,而且只要程序不被杀死,该实例对象就不会被释放,并且该对象是全局的,能够被整个系统访问到. 在应用这个模 ...
- AJAX使用四步曲
前言 AJAX这个东西还是很模糊的,下面会对AJAX这个技术进行详细讲解一些,另外,在网上商城中应用到了,使用它有四个步骤,下面详细介绍一些. 内容 定义: AJAX=异步JavaScript和XML ...
- hdu3518(后缀数组)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3518 题意: 给出一个字符串, 问其中有多少字串出现了两次以上(计算次数时不能彼此覆盖, 如 &qu ...
- dede地图显示最新文章的解决方法
以DEDECMS5.6为例:sitemap.htm 在/templets/plus/目录里,就算添加了织梦相关标签调用,但却不能显示文章. 这是因为makehtml_map.php不能解析织梦的相关调 ...
- 解释器模式Interpreter详解
原文链接:https://www.cnblogs.com/java-my-life/archive/2012/06/19/2552617.html 在阎宏博士的<JAVA与模式>一书中开头 ...
- c++运算符重载-如何决定作为成员函数还是非成员函数
The Decision between Member and Non-member The binary operators = (assignment), [] (array subscripti ...