【POJ1416】Shredding Company
本题知识点:深度优先搜索 + 回溯
本题题意很简单,就是有一条位数不超过6的数字纸条,问你怎么剪这纸条,使得得到的纸条的值的总和最接近目标值(总和不能超过目标值)。
比如第一个样例
50 12346
12346可以剪成
1 2 3 4 6(总和16);12 34 6(总和52)等,其中最接近且不大于目标值的就是剪成1 2 34 6,总和是43,所以输出
43 1 2 34 6;
如果怎么剪都是大于目标值则输出
error
如果剪法有多种情况则输出
rejected
比如111 33333就有多种不同样的剪法带来相同的总和。
需要注意的是,数据输入保证没有前置0,但中间0也是要算进一种情况的,
比如 6 1104这例子1 1 0 4 与 1 1 04就属于两种不同的情况,但他们的和相等,所以就输出rejected了
那应该怎么剪呢?
我这里的做法是利用dfs的思想,到某一位上就有剪与不剪这种情况。
比如12346这条纸条,当我指到1这个数字上时,我剪下来就是1 2346,不剪就仍是12346,等到指到2时,剪下来就是12 346,如果前面1也剪了话就是 1 2 346了......依次类推,就可以写出dfs的递归过程。
注意回溯/(详细可看代码)
数据不大
// POJ 1416
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int tar, num, Len, ans, minn;
bool ok, take;
int in[102], Ans[102];
int cnt_in, cnt_ans;
void setLen(){ // Len 记录可以剪与不剪的长度
Len = 0;
int q = num;
while(q){ Len++; q /= 10; }
}
void dfs(int r, int len, int tot){ // r:当前纸条 len:判定到第几个数上 tot:剪下后的总和
if(len == Len){ // 判断到最后的数字
tot += r; // 加上最后的r
if(r != 0) // 如果不是 0 要入数组(下面对应)
in[cnt_in++] = r;
if(tot <= tar){ // 先要比目标值小
if(tar-tot < minn){ // 然后找差值最小的
ok = true;
minn = tar - tot;
ans = tot;
for(int i = 0; i < cnt_in; i++) Ans[i] = in[i]; cnt_ans = cnt_in;
take = false; // 更新后就有新的答案数组 take 也要改变
// 数据更新
}
else if(tar - tot == minn) { // 如果是相同的差值 判断是否重复(如果数组元素是一样的则不算)
bool equ = true;
if(cnt_ans == cnt_in){
for(int i = 0; i < cnt_in; i++){
if(Ans[i] != in[i]) {
equ = false;
}
}
}
else equ = false;
if(!equ) take = true;
}
}
if(r != 0)
cnt_in--; // 同样也是回溯
return ;
}
// 记录当前 r 的长度
int q = r, now = 0;
while(q){ now++; q /= 10; }
int pla = len - (Len - now); // 应该往右几位截取数据(这个规则可以自己动手算一算)
int zero = 1;
for(int i = 0; i < Len - len - 1; i++) zero *= 10;
// 该位切
int cro = r / zero; // 被剪下来的数
in[cnt_in++] = cro; // 放进数组里(顺序表思路)
dfs(r % zero, len + 1, tot + cro);
cnt_in--; // 回溯,丢掉
// 该位不切
if(len == Len - 1 && num % 10 == 0 && r == 0) in[cnt_in++] = r; // 特判:判断原字条最后一位是否为0,如果是要入数组(取决于最后判断时的判断条件)
dfs(r, len + 1, tot);
if(len == Len - 1 && num % 10 == 0 && r == 0)cnt_in--; // 对于特判的回溯
}
int main()
{
while(~scanf("%d %d", &tar, &num) && tar + num){
// 初始化工作
memset(in, 0, sizeof(in));
memset(Ans, 0, sizeof(Ans));
cnt_in = cnt_ans = 0;
ok = take = false; // ok 记录有满足的条件 take 记录是否有重复的满足条件
ans = 0;
minn = 0x3f3f3f3f;
setLen();
// 跑程序只是有一个dfs()
dfs(num, 0, 0);
// 答案输出
if(ok && !take) {
printf("%d ", ans);
for(int i = 0; i < cnt_ans; i++)
printf("%d%c", Ans[i], i == cnt_ans - 1 ? '\n' : ' ');
}
else if(ok && take) printf("rejected\n");
else if(!ok) printf("error\n");
}
return 0;
}
【POJ1416】Shredding Company的更多相关文章
- 【CF125E】MST Company(凸优化,最小生成树)
[CF125E]MST Company(凸优化,最小生成树) 题面 洛谷 CF 题解 第一眼看见就给人丽洁姐那道\(tree\)一样的感觉. 那么二分一个权值,加给所有有一个端点是\(1\)的边, 然 ...
- 【POJ 1416】Shredding Company
题 题意 给你一个target number,和一个最多六位的数num,让你把数分段,使总和最接近但不大于target number. 如果只有一种方法就输出总和.分段,如果有多种方法,输出rejec ...
- POJ 1416 Shredding Company【dfs入门】
题目传送门:http://poj.org/problem?id=1416 Shredding Company Time Limit: 1000MS Memory Limit: 10000K Tot ...
- POJ1416——Shredding Company(DFS)
Shredding Company DescriptionYou have just been put in charge of developing a new shredder for the S ...
- 【CodeForces】790 C. Bear and Company 动态规划
[题目]C. Bear and Company [题意]给定大写字母字符串,交换相邻字符代价为1,求最小代价使得字符串不含"VK"子串.n<=75. [算法]动态规划 [题解 ...
- 【lightoj-1039】A Toy Company(BFS)
The toy company "Babies Toys" has hired you to help develop educational toys. The current ...
- poj1416 Shredding Company
Shredding Company Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 5379 Accepted: 3023 ...
- 【codeforces 794C】Naming Company
[题目链接]:http://codeforces.com/contest/794/problem/C [题意] 有n个位置; 两个人; 每个人都有n个字符组成的集合s1,s2(可以有重复元素); 然后 ...
- 【VK Cup 2015 - Finals D】Restructuring Company
[题目链接]:http://codeforces.com/problemset/problem/566/D [题意] 给你n个人; 一开始每个人都隶属于一个部门; 之后给你q个操作; 3种操作类型; ...
随机推荐
- Spring Security实现OAuth2.0授权服务 - 基础版
一.OAuth2.0协议 1.OAuth2.0概述 OAuth2.0是一个关于授权的开放网络协议. 该协议在第三方应用与服务提供平台之间设置了一个授权层.第三方应用需要服务资源时,并不是直接使用用户帐 ...
- 【转载】 C#中ArrayList集合类的使用
在C#的集合操作过程中,我们一般常用的集合类为List集合,List集合是一种强类型的泛型集合,其实还有一个ArrayList集合类,ArrayList集合类则非泛型类的集合,并且ArrayList集 ...
- Django:RestFramework之-------认证
3 restframework-认证 3.1APIView 认证: 认证是否已经登陆,如果已经登陆返回元组,如果没有登陆报错 源码流程: 执行dispatch方法: def dispatch(self ...
- 《微信小程序项目开发实战:用WePY、mpvue、Taro打造高效的小程序》(笔记1)WePY开发环境的安装
WePY的安装或更新都通过npm进行,全局安装或更新WePY命令行工具,使用以下命令: npm install wepy-cli -g 稍等片刻,成功安装后,即可创建WePY项目. 注意:如果npm安 ...
- python3常用的内置函数
数学相关 abs(a) : 求取绝对值.abs(-1) max(list) : 求取list最大值.max([1,2,3]) min(list) : 求取list最小值.min([1,2,3]) su ...
- SVM 实现多分类思路
svm 是针对二分类问题, 如果要进行多分类, 无非就是多训练几个svm呗 OVR (one versus rest) 对于k个类别(k>2) 的情况, 训练k个svm, 其中, 第j个svm用 ...
- Pandas 之 DataFrame 常用操作
import numpy as np import pandas as pd This section will walk you(引导你) through the fundamental(基本的) ...
- Prometheus学习笔记(3)什么是node_exporter???
目录 Node_exporter安装配置启动 Node_exporter安装配置启动 node_exporter安装在被监控端,安装方式也比较简单,直接下载解压安装即可,默认启动后监听9100端口. ...
- Java的常见术语(PO/POJO/VO/BO/DAO/DTO)
PO(persistant object) 持久对象在o/r 映射的时候出现的概念,如果没有o/r映射,就没有这个概念存在了.通常对应数据模型(数据库),本身还有部分业务逻辑的处理.可以看成是与数据库 ...
- 【异常】微博生成短链异常{"request":"/2/short_url/shorten.json","error_code":"10014","error":"Insufficient app permissions!"}
一.之前的调用方式 这种方式用了大约有一年时间,之前没有问题,但是2019-8-28号突然不行了,可能是由于微博对该接口的调用做了限制.不允许通过传递source参数的方式进行请求 该接口微博API文 ...