CF58E Expression 搜索
题目传送门:http://codeforces.com/problemset/problem/58/E
题意:给出一个形如$x+y=z$(不一定正确)的式子,试输出一个$a+b=c$的式子,满足:$1.$等式成立;$2.$等式由给出的$x+y=z$等式加入若干数字得到;$3.$在满足前两个要求的前提下式子最短。若有多组输出任意一组均可。给出的等式中所有的数大小均不超过$10^6$
与虫食算一题很相似。
考虑从最后一位开始进行搜索。对于其中某一位,至多只有两种情况:加入一个数使这一位上运算成立,或者这一位上本就运算成立,无需加入数。
所以答案范围在$10^{14}$之内,搜索可以完成
注意本题的细节:在运算某一位时,如果某一个数结果为$0$,而更高位上还需要补数字,这是不可行的。
因为各种魔改所以代码极其难看
#include<bits/stdc++.h>
using namespace std;
][] , ans[][] , nA , nB , nC , minN = , cnt , t[];
//now是当前加了哪些数
//ans是最终答案加了哪些数
void dfs(int a , int b , int c , int num , int jw , int cou , bool ifA , bool ifB){
//abc记录当前三个数还有多少没有算
//num记录加了几个数
//cou表示加法共有几位
//ifA与ifB表示是否还能够再a或b上加数
if(!a && !b && !c && !jw){
minN = num;
cnt = cou;
memcpy(ans , now , sizeof(now));
return;
}
//注意:下面的四个dfs前的if中的条件都有c!=0!!!
+ b % - c % + jw == && c)
dfs(a / , b / , c / , num , , cou + , a ? : , b ? : );
+ b % - c % + jw == && c)
dfs(a / , b / , c / , num , , cou + , a ? : , b ? : );
else{
) return;
now[num][] = ++cou;
if(!ifA && c){
now[num][] = ;
now[num][] = (c % - b % - jw + ) % ;
bool f = ifB;
;
dfs(a , b / , c / , num , (now[num][] + b % + jw - c % ) / , cou , ifA , ifB);
ifB = f;
}
if(!ifB && c){
now[num][] = ;
now[num][] = (c % - a % + - jw) % ;
bool f = ifA;
) ifA = ;
dfs(a / , b , c / , num , (now[num][] + a % + jw - c % ) / , cou , ifA , ifB);
ifA = f;
}
now[num][] = ;
now[num][] = (a % + b % + jw) % ;
;
;
dfs(a / , b / , c , num , (a % + b % + jw - now[num][]) / , cou , ifA , ifB);
}
}
int main(){
int a , b , c;
bool f;
scanf("%d+%d=%d" , &a , &b , &c);
dfs(a , b , c , , , , , );
//一个很迷的输出
;
] - ) p++;
; i <= cnt ; i++)
] == i){
t[i] = ans[p++][];
] - ) p++;
}
else{
t[i] = a % ;
a /= ;
}
f = ;
for(int i = cnt ; i ; i--)
if(f || t[i]){
putchar(t[i] + ');
f = ;
}
putchar('+');
p = ;
] - ) p++;
; i <= cnt ; i++)
] == i){
t[i] = ans[p++][];
] - ) p++;
}
else{
t[i] = b % ;
b /= ;
}
f = ;
for(int i = cnt ; i ; i--)
if(f || t[i]){
putchar(t[i] + ');
f = ;
}
putchar('=');
p = ;
] - ) p++;
; i <= cnt ; i++)
] == i){
t[i] = ans[p][];
p++;
] - ) p++;
}
else{
t[i] = c % ;
c /= ;
}
f = ;
for(int i = cnt ; i ; i--)
if(f || t[i]){
putchar(t[i] + ');
f = ;
}
;
}
CF58E Expression 搜索的更多相关文章
- Codeforces 58E Expression (搜索)
题意:给你一个可能不正确的算式a + b = c, 你可以在a,b,c中随意添加数字.输出一个添加数字最少的新等式x + y = z; 题目链接 思路:来源于这片博客:https://www.cnb ...
- [GodLove]Wine93 Tarining Round #7
比赛链接: http://vjudge.net/contest/view.action?cid=47643#overview 比赛来源: 2012 ACM/ICPC Asia Regional Han ...
- Emacs快捷键列表
C = ControlM = Meta = Alt | EscDel = Backspace 基本快捷键(Basic)C-x C-f "find"文件, 即在缓冲区打开/新建一个文 ...
- EMACS快捷键
C = Control M = Meta = Alt | Esc Del = Backspace 基本快捷键(Basic) C-x C-f "find"文件, 即在缓冲区打开/新建 ...
- Emacs快捷键(较全)
C = Control M = Meta = Alt | Esc Del = Backspace 基本快捷键(Basic) C-x C-f "find"文件, 即在缓冲区打开/新建 ...
- lucene 范围搜索表达式(range expression)
实际测试 lucene范围符号,大于等于或小于等于符号[],大于或小于符号{} newIntRange或newLongRange一样 代码: // test lucen ...
- jQuery find() 搜索所有段落中的后代 C# find() 第一个匹配元素 Func 有返回值 Action是没有返回值 Predicate 只有一个参数且返回值为bool 表达式树Expression
所有p后代span Id为 TotalProject 的 select 标签 的后代 option标签 为选中的 text using System; using System.Collections ...
- Expression表达式 实现and、or搜索
用法: [HttpPost] public ActionResult GetBannerList(int pageIndex, int pageSize, string search) { Resul ...
- WPF 自定义搜索框
控件中的搜索图标下载地址:http://www.easyicon.net/1183666-Search_icon.html 搜索框设计过程比较简单: 1.先定义一个Rectangle作为背景 2. ...
随机推荐
- 测试思想-集成测试 关于接口测试 Part 2
关于接口测试 by:授客 QQ:1033553122 ------------------接Part 1---------------------- 5. 用例设计思想(举例说明) 如上表,是某 ...
- Angular基础(三) TypeScript
一.模仿Reddit a) 运行ng new –ng4angular-reddit创建应用,从随书代码中复制样式文件,新建组件app-root,代码为: 界面可以看到了: b) 对于界面输入的数据,获 ...
- 基于Jmeter和Testlink的自动化测试框架研究与实施
关于测试框架搭建的详细过程,会在另一篇文章中详细介绍:http://www.cnblogs.com/leeboke/p/6145977.html 摘 要 目前基于Jmeter的接口自动化测试框架,大多 ...
- (网页)textarea去掉回车换行
转自CSDN: 1,把textarea内输入的内容中有回车换行的转成<br />传给后台, var content = $("#text").val().replace ...
- matlab练习程序(FAST特征点检测)
算法思想:如果一个像素与它邻域的像素差别较大(过亮或过暗) , 那它更可能是角点. 算法步骤: 1.上图所示,一个以像素p为中心,半径为3的圆上,有16个像素点(p1.p2.....p16). 2.定 ...
- Python数据清洗基本流程
# -*- coding: utf-8 -*-"""Created on Wed Jul 4 18:40:55 2018 @author: zhen"" ...
- 如何将 asp.net core 应用进行 docker 容器部署
asp.net core 部署在 docker 容器中比较简单,但常因asp.net core程序发布的问题造成容器无法正常启动.现在把详细的操作的步骤记录如下: 一.asp.net core web ...
- Jenkins的配置从节点中默认没有Launch agent via Java Web Start,该如何配置使用
Jenkins的配置从节点中默认没有Launch agent via Java Web Start,如下图所示,而这种启动方式在Windows上是最方便的. 如何设置才能让出来呢? 1:打开" ...
- 7z常用命令行&7z检测压缩包完整性&7z压缩包错误不执行rsync同步
7Z简介&常用命令 7Z脚本使用说明 7Z检测压缩包完整性脚本 7Z压缩包错误不执行Rsync脚本 1.7Z简介&常用命令 ⑴简介: 7z,全称7-Zip, 是一款开源软件.是目前公认 ...
- emacs org-mode文件转html文件
Table of Contents 1. 发布站点 by emacs org-mode 1.1 org-mode 自带的导出方法 1.2 批量导出 1.3 css 美化 1.4 导出html 1. 发 ...