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. Entity Framework Tutorial Basics(36):Eager Loading

    Eager Loading: Eager loading is the process whereby a query for one type of entity also loads relate ...

  2. 1506-122 (S) Expecting pointer to struct or union.

    __你们 大胆 猜 是什么错.. __ 很尴尬的错误..就是 结构体指针. ___只有结构体 指针 可以用 ->   这个符号哦.. 所以 你只要 将  ->  改成   .    , 就 ...

  3. GridView里的按钮事件

    http://www.cnblogs.com/insus/archive/2012/09/22/2697862.html using System;using System.Collections.G ...

  4. IDEA 基本操作

    1.IDEA 编译的JDK问题 点击出错的模块 将这个改成8,但是改了这个还是不行,项目一编译他有回去了. 正确的做法: 在跟pom.xml 中增加如下代码: <build> <pl ...

  5. json解析(自动判断是jsonArray和jsonObject)

    因为想做一个接口自动化框架,已经实现了接口的访问和连接及获取接口返回的json数据,但json数据的解析是个麻烦的事情,所以写一个简单的版本记录一下.后续会进行优化,实现方法分离以及自动识别循环解析返 ...

  6. Beautiful Sequence

    Beautiful Sequence 给定一些数(可能相同),将它们随机打乱后构成凹函数,求概率 .N<=60 . 首先,这种题求概率事实上就是求方案.所以现在要求的是用这些数构成凹函数的方案数 ...

  7. centos-7.4_ceph-12.2.4部署

    centos-7.4_ceph-12.2.4部署: 前言: 基于centos7.4安装ceph-luminous的主要步骤有一下几点: 1.安装centos7.4的系统,并配置网卡 2.安装前的环境配 ...

  8. luogu1556 幸福的路

    注意到\(n\le10\),所以枚举经过的拐弯牛的所有排列. 注意到STL是一个好东西,所以我这里偷懒直接使用了next_permutation 枚举所有n的排列,对于每一个排列也就是经过拐弯牛的顺序 ...

  9. Leetcode 91. Decode Ways 解码方法(动态规划,字符串处理)

    Leetcode 91. Decode Ways 解码方法(动态规划,字符串处理) 题目描述 一条报文包含字母A-Z,使用下面的字母-数字映射进行解码 'A' -> 1 'B' -> 2 ...

  10. 再谈hive-1.0.0与hive-1.2.1到JDBC编程忽略细节问题

    不多说,直接上干货,这个问题一直迷惑已久,今天得到亲身醒悟. 所以,建议hadoop-2.6.0.tar.gz的用户与hive-1.0.0搭配使用.当然,也可以去用高版本去覆盖它. log4j:WAR ...