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大模拟的更多相关文章

  1. cf Permute Digits(dfs)

    C. Permute Digits You are given two positive integer numbers a and b. Permute (change order) of the ...

  2. 【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 ...

  3. Codeforces 915 C. Permute Digits (dfs)

    题目链接:Permute Digits 题意: 给出了两个数字a,b(<=1e18),保证a,b都不带前缀0.用a的字符重组一个数字使这个值最大且小于b.(保证这个值存在) 题解: 这题遇到了不 ...

  4. CodeForces-915C Permute Digits

    C. Permute Digits time limit per test 1 second memory limit per test 256 megabytes input standard in ...

  5. ACdream 1188 Read Phone Number (字符串大模拟)

    Read Phone Number Time Limit:1000MS     Memory Limit:64000KB     64bit IO Format:%lld & %llu Sub ...

  6. 2016ACM-ICPC网络赛北京赛区 1001 (trie树牌大模拟)

    [题目传送门] 1383 : The Book List 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 The history of Peking University ...

  7. [CSP-S模拟测试]:引子(大模拟)

    题目描述 网上冲浪时,$Slavko$被冲到了水箱里,水箱由上而下竖直平面.示意图如下: 数字$i$所在的矩形代表一个编号为$i$的水箱.1号水箱为水箱中枢,有水管连出.除了$1$号水箱外,其他水箱上 ...

  8. HDU 5920 Ugly Problem 高精度减法大模拟 ---2016CCPC长春区域现场赛

    题目链接 题意:给定一个很大的数,把他们分为数个回文数的和,分的个数不超过50个,输出个数并输出每个数,special judge. 题解:现场赛的时候很快想出来了思路,把这个数从中间分为两部分,当位 ...

  9. AC日记——神奇的幻方 洛谷 P2615(大模拟)

    题目描述 幻方是一种很神奇的N*N矩阵:它由数字1,2,3,……,N*N构成,且每行.每列及两条对角线上的数字之和都相同. 当N为奇数时,我们可以通过以下方法构建一个幻方: 首先将1写在第一行的中间. ...

随机推荐

  1. 4. 内网渗透之IPC$入侵

    IPC$连接 IPC$的概念: IPC$(Internet Process Connection)是共享”命名管道”的资源,它是为了让进程间通信而开放的命名管道,可以通过验证用户名和密码获得相应的权限 ...

  2. rpm bug

    rpm无法安装 今天安装java时候,下载的rpm的包,但是用linux打开时候发现不能正常打开. 错误详情 主要是rpm安装时候的错误,java提示的错误就没有记录了. Reading packag ...

  3. [译]Javascript中的函数

    本文翻译youtube上的up主kudvenkat的javascript tutorial播放单 源地址在此: https://www.youtube.com/watch?v=PMsVM7rjupU& ...

  4. [译]Javascript中的数列

    本文翻译youtube上的up主kudvenkat的javascript tutorial播放单 源地址在此: https://www.youtube.com/watch?v=PMsVM7rjupU& ...

  5. 2016年第七届蓝桥杯省赛试题(JavaA组)

    1.结果填空 (满分3分)2.结果填空 (满分5分)3.结果填空 (满分9分)4.代码填空 (满分11分)5.代码填空 (满分13分)6.结果填空 (满分15分)7.结果填空 (满分19分)8.程序设 ...

  6. Java50道经典习题-程序48 数字加密

    题目:某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换.分析:例如原始 ...

  7. JSPatch在MAC下的使用

    简单调研JSPatch的使用,之所以在MAC下是因为可以创建一个命令行的应用,简化无关代码.具体做法如下: 第一步,去https://github.com/bang590/JSPatch/tree/m ...

  8. models说明

    class UserType(models.Model): caption = models.CharField(max_length=32) class User(models.Model): na ...

  9. 树形DP【洛谷P3047】 [USACO12FEB]附近的牛Nearby Cows

    P3047 [USACO12FEB]附近的牛Nearby Cows 农民约翰已经注意到他的奶牛经常在附近的田野之间移动.考虑到这一点,他想在每一块土地上种上足够的草,不仅是为了最初在这片土地上的奶牛, ...

  10. 插头DP学习笔记

    插头DP(我也不知道该怎么定义...)是一种类似于洛谷题目([模板]插头DP)的题目 题目特征为: 在棋盘上 某一维的数据范围很小 完全铺满 计数问题 直接看题吧. [模板]插头DP 给出n*m的方格 ...