CF 317A(Perfect Pair-广义Fib序列p,q=1性质2&加法增长极)

A. Perfect Pair
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

Let us call a pair of integer numbers m-perfect, if at least one number in the pair is greater than or equal to m. Thus, the pairs (3, 3) and (0, 2) are 2-perfect while the pair (-1, 1) is not.

Two integers xy are written on the blackboard. It is allowed to erase one of them and replace it with the sum of the numbers, (x + y).

What is the minimum number of such operations one has to perform in order to make the given pair of integers m-perfect?

Input

Single line of the input contains three integers xy and m ( - 1018 ≤ xym ≤ 1018).

Please, do not use the %lld specifier to read or write 64-bit integers in C++. It is preffered to use the cincout streams or the %I64dspecifier.

Output

Print the minimum number of operations or "-1" (without quotes), if it is impossible to transform the given pair to the m-perfect one.

Sample test(s)
input
1 2 5
output
2
input
-1 4 15
output
4
input
0 -1 5
output
-1
Note

In the first sample the following sequence of operations is suitable: (1, 2)  (3, 2)  (5, 2).

In the second sample: (-1, 4)  (3, 4)  (7, 4)  (11, 4)  (15, 4).

Finally, in the third sample xy cannot be made positive, hence there is no proper sequence of operations.


首先,这题尽管我用了Sx的公式(可二分),但是可以暴力(加法增长极很大)

只需要把负数弄好就行.

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<functional>
#include<cmath>
#include<cctype>
using namespace std;
#define For(i,n) for(int i=1;i<=n;i++)
#define Rep(i,n) for(int i=0;i<n;i++)
#define Fork(i,k,n) for(int i=k;i<=n;i++)
#define ForD(i,n) for(int i=n;i;i--)
#define Forp(x) for(int p=pre[x];p;p=next[p])
#define RepD(i,n) for(int i=n;i>=0;i--)
#define MEM(a) memset(a,0,sizeof(a))
#define MEMI(a) memset(a,127,sizeof(a))
#define MEMi(a) memset(a,128,sizeof(a))
#define INF (1e18)
#define MAXN (1000000)
long long x,y,m;
long long f[MAXN]={0,1,1};
int n=0;
long long work()
{
	if (max(x,y)>=m) return 0;
	long long j=0;
	if (x==0&&y==0) return -1;
	if (x<0&&y<0) return -1;
	bool b=0;
	while (max(x,y)<m)
	{
		if (x+y<=min(x,y)) return -1;
		if (x>y) swap(x,y);
		if (x>0&&y>0)
		{
			int k=1;
			while (f[k]*x+f[k+1]*y<m) k++;
			j+=k;
			return j; 
		}	
		else if (!b&&x<0&&y>0)
		{
			long long k=-x/y;
			if (m<0) k=(m-x)/y;
			j+=k;
			x+=k*y;
			b=1;
		}
		else
		{
			j++;
			x+=y;
		}	
	}
	return j;
}
int main()
{
//	freopen(".in","r",stdin);
//	freopen(".out","w",stdout);

	for(n=3;f[n-1]<INF;n++) f[n]=f[n-1]+f[n-2];
	n--;
//	For(i,n) cout<<f[i]<<' ';
	while (cin>>x>>y>>m)
		cout<<work()<<endl;

	return 0;
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用的描述,当用户在安装某些软件时遇到“无法启动此程序,因为计算机中丢失api-ms-win-core-path-l1-1-0.dll”的错误提示时,可以采取以下三种解决方法: 解决方法一是将下载好的api-ms-win-core-path-l1-1-0.dll文件放到系统路径中。系统路径的默认位置是在。 解决方法二是检查操作系统中是否缺少了api-ms-win-core-path-l1-1-0.dll文件。如果确实缺少该文件,可以尝试重新安装或修复对应的软件,以恢复该文件的缺失。 解决方法三是更新操作系统。有时,旧版本的操作系统可能会导致某些文件丢失,升级到最新版本的操作系统可能会解决这个问题。 综上所述,如果mysqlsh丢失api-ms-win-core-path-l1-1-0.dll文件,可以尝试按照这些解决方法来解决问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [api-ms-win-core-path-l1-1-0.dll丢失?](https://blog.csdn.net/xitongzhijianet/article/details/129184860)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [python打包程序win7下运行丢失api-ms-win-crt-runtime-l1-1-0.dll的解决方法](https://download.csdn.net/download/cq317a/14007031)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值