Codeforces 346C Number Transformation II 构造

news/2024/7/7 19:58:43

题目链接:点击打开链接

= = 990+ms卡过

#include<stdio.h>
#include<iostream>
#include<string.h>
#include<algorithm>
#include<vector>
#include<set>
using namespace std;
#define N 100010
#define L(x) (x<<1)
#define R(x) (x<<1|1)
#define ll int
ll n,m,k,a,b;
ll x[N];
bool cmp(ll z,ll y){return z>y;}
set<int>myset;
set<int>::iterator p;
int main(){
	ll i,j;
	while(cin>>n){
		myset.clear();
		for(i=1;i<=n;i++)scanf("%d",&j),myset.insert(j);
		cin>>a>>b;
		if(a==b){puts("0");continue;}
		n = myset.size();
		i = 1;
		for(p = myset.begin(); p!=myset.end(); p++,i++)x[i] = *p;
		sort(x+1,x+1+n,cmp);
		ll step = 0;
		ll l = 1;
		while(x[l]>a && l<=n)l++;
		while(x[l]>(a>>1) && (a-x[l])>(a-b))l++;
		if(l>n){cout<<a-b<<endl;continue;}

		while(a!=b){
			step++;
			ll now = 1, cha = a-b;

			for(i = l;i<=n;i++)
			{
				if(now>=x[i])break;
				ll tmp = a-((a/x[i])*x[i]);
				if(tmp<=now || tmp>cha)continue;
				now = tmp;
			}
			a-=now;
			while(x[l]>a&&l<=n)l++;
			while(x[l]>(a>>1) && (a-x[l])>cha)l++;
			if(l>n)break;
		}
		cout<<step+a-b<<endl;
	}
	return 0;
}


转载于:https://www.cnblogs.com/yxwkf/p/5425148.html


http://www.niftyadmin.cn/n/3291199.html

相关文章

成为一个CTO需要具备什么条件?

1、参与制定公司发展战略、年度经营计划、预算方案、研究决策&#xff0c;组织研究行业最新产品的技术发展方向&#xff0c;主持制定公司技术发展路线、技术发展战略规划&#xff0c;规划公司产品。 2、领导分管部门制度并组织实施年度工作计划&#xff0c;完成年度任务目标。 …

Duilib实现QQ聊天窗口晃动

转载:http://blog.csdn.net/arbboter/article/details/26282717 转载:http://blog.csdn.net/zerolusta/article/details/5857191 点击抖动函数: 1 void Shake()2 {3 int ty3;4 int nFre 30;5 RECT m_rect; 6 GetWindowRect(this->m_hWnd, &m_rect)…

从刘谦身上领会到了些东西

2002年的时候我就看过刘谦的街头魔术秀了&#xff0c;直到刘谦登上CCTV凭借一般的魔术功力较强的表演能力迅速走红&#xff0c;我的体会是&#xff0c;觉得当自己的技术水平已经没有突破的时候&#xff0c;一定要去发掘身上其他的优点长处&#xff0c;而不是一根茎的死钻技术走…

Struts框架2ActionError类 内部资料 请勿转载 谢谢合作

ActionError类从不独立进行错误处理&#xff0c;它们总是被存储在ActionErrors对象中。ActionErrors对象保存ActionError类的集合以及它们特定的属性值&#xff0c;我们可以使用自己定义的属性值&#xff0c;或是使用ActionErrors.GLOBAL_ERROR. 下面是典型Action类的perform()…

环境变量添写

如&#xff1a;C:/Program Files/Microsoft Visual Studio 9.0/VC/bin/nmake.exe要想 CMD下&#xff1a; >nmake 直接运行。分3步 1.在用户环境变量中path中添加;C:/Program Files/Microsoft Visual Studio 9.0/VC/bin加最后一般要加分号 2.再添加如nmake变量名&#xf…

linux 下多线程下调试

要点是先运行程序&#xff0c;再attach线程号进行调试。1。先运行你的主程序2。使用ps查看你程序的线程号&#xff0c;或者在线程程序里打印出来3。运行gdb&#xff0c;运行“attach 线程号”4。info stack看运行到哪里了&#xff0c;设线程文件中的断点5。跟踪调试6。“detach…

进系统一直转圈圈_进博会网红展品加强版亮相,“元老级”参展商收获的不只是订单...

文/羊城晚报全媒体记者 莫谨榕图/羊城晚报全媒体记者 陶奕燃在今年举行的第三届进博会上&#xff0c;“老朋友”积极赴约&#xff0c;参加过进博会的世界500强及行业龙头企业中&#xff0c;每十家就有七家重返进博会“四叶草”展馆。在进博会现场&#xff0c;羊城晚报全媒体记者…

实现dedecms(PC端)全站动态浏览 并实现伪静态

dedecms默认是生成静态文件&#xff0c;如何实现织梦(PC端)全站动态浏览呢&#xff1f; 织梦全站动态浏览方法 1. 修改首页为动态浏览 后台-生成-更新首页-勾选“仅动态浏览” 2. 修改栏目页为动态浏览 ①添加或编辑栏目时勾选“使用动态页” ②如果有已添加但未设置动态浏览的…