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写在第一行的中间. ...
随机推荐
- dojo1.7 加载器
原文地址:http://dojotoolkit.org/documentation/tutorials/1.7/modules/ dojo现在支持在异步模块异步(AMD)定义中加入模块写入功能了,这使 ...
- eval实例
.... var sel_MedicineType = 'sel_MedicineType' + lastIndex; eval(sel_MedicineType + "= new C_Se ...
- AI-Info-Micron-Insight:工业 5.0,伟大的思想将殊途同归
ylbtech-AI-Info-Micron-Insight:工业 5.0,伟大的思想将殊途同归 1.返回顶部 1. 工业 5.0,伟大的思想将殊途同归 两个头脑比一个好吗?似乎如此,尤其是当其中一个 ...
- [SinGuLaRiTy] 2017-07-22 NOIP2017 模拟赛
[SInGuLaRiTy-1029] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. <全是看看代码就会的水题,偷个懒不单独写题解了~& ...
- loj #2007. 「SCOI2015」国旗计划
#2007. 「SCOI2015」国旗计划 题目描述 A 国正在开展一项伟大的计划 —— 国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这项计划需要多名边防战士以接力的形式共同完成 ...
- 亿级PV请求的三种负载均衡技术(转)
http://www.360doc.com/content/17/1126/23/50145453_707419125.shtml 目录 DNS轮询 LVS负载均衡 DR模式 NAT模式 ...
- webpack热更新实现
原文地址:webpack热更新实现 webpack,一代版本一代神,代代版本出大神.如果你的webpack和webpack-dev-server版本大于2小于等于3.6,请继续看下去.其它版本就必浪费 ...
- P2155 [SDOI2008]沙拉公主的困惑
\(\color{#0066ff}{ 题目描述 }\) 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为1到N的阶乘,但是,政府只发行编号与M!互质的钞票.房地产第一大 ...
- sklearn.metrics.roc_curve使用说明
roc曲线是机器学习中十分重要的一种学习器评估准则,在sklearn中有完整的实现,api函数为sklearn.metrics.roc_curve(params)函数. 官方接口说明:http://s ...
- Java Applet 素数小程序
en... 1. Applet 这个远古的东西,今天我同学让我帮他看看代码,说applet运行出错.额,反正闲着也是闲着,看看呗 ,结果看到代码...4 2.就是实现这破玩意 package calc ...