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写在第一行的中间. ...
随机推荐
- Entity Framework Tutorial Basics(6):Model Browser
Model Browser: We have created our first Entity Data Model for School database in the previous secti ...
- review backpropagation
The goal of backpropagation is to compute the partial derivatives ∂C/∂w and ∂C/∂b of the cost functi ...
- C语言关键字:auto、static、register、const、volatile 、extern 总结 <转>
auto 这个这个关键字用于声明变量的生存期为自动,即将不在任何类.结构.枚举.联合和函数中定义的变量视为全局变量,而在函数中定义的变量视为局部变量.这个关键字不怎么多写,因为所有的变量默认就是aut ...
- 数据结构--树--AVL树
详情查看:http://www.cnblogs.com/skywang12345/p/3577360.html
- 简单的使用rabbitmq的例子
1.创建了两个项目 : (1).spring_cloud_rabbitmq_send 消息发送者 (2).spring_cloud_rabbitmq_receive 消息接受者 2. 添加rabbi ...
- 未能加载文件或程序集“Interop.SQLDMO”或它的某一个依赖项
程序运行没问题,当您配置好IIS后,打开安装向导时出现以下错误信息: 解决办法为:在IIS应用程序池中“启用32位应用程序”, 1,打开IIS应用程序池,选中相应应用程序池,点击右侧“高级设置” 2, ...
- GitHub下载代码到本地
1.git clone git@github.com:Sehunwy/test.git(加粗的是下载的地址) 2.下载完成,此时本地是这样的: 参考:https://blog.csdn.net/qq ...
- epoll简介
1.epoll简介 epoll是I/O事件通知工具,与select/poll相比,epoll最大的好处在于它不会随着监听fd数目的增长而效率降低.epoll API既可以用作edge触发的接口,也可以 ...
- mysql在linux下的安装与优化
mysql5.6 http://www.cnblogs.com/bookwed/p/5896619.html mysql5.7 http://blog.csdn.net/wb96a1007/artic ...
- oracle修改连接数
使用 sqlplus登陆 sqlplus system 然后切换到sysdba模式 conn ?/ as sysdba 查询当前的processes sessions的大小 show ...