【9308】极值问题
来源:互联网 发布:php接口开发规范 编辑:程序博客网 时间:2024/05/22 05:52
Time Limit: 10 second
Memory Limit: 2 MB
问题描述
已知m,n为整数,且满足下列两个条件:
1、m、n∈{1,2…,k},即1≤m,n≤k;
2、(n^2-m*n-m^2)^2=1。
编程输入正整数k(1≤k≤10^9),求一组满足上述两个条件的m,n,并且使得n^2+m^2的值最大。
Input
输入正整数k
Output
输出满足最大值的m和n
Sample Input
100
Sample Output
m=55
n=89
【题目链接】:http://noi.qz5z.com/viewtask.asp?id=9308
【题解】
(n^2-m*n-m^2)^2=1
(m^2+m*n-n^2)^2=1
(m^2+2*m*n+n^2-m*n-2*n^2)^2=1
(m^2+2*m*n+n^2-m*n-n^2-n^2)^2=1
(m^2+2*m*n+n^2-n*(m+n)-n^2)^2=1
((m+n)^2-n*(m+n)-n^2)^2=1
则令n’=(m+n),m’=n;
(n’^2-m’*n’-m’^2)^2=1
所以如果n和m是符合要求的解;
则n=(m+n)和m=n也是方程的解;
而由观察可知n=1,m=1是方程的解
所以n=2,m=1也是方程的解;
则n=3;m=2也是方程的解。。
就是斐波那契数列了;
递推下就好;
【完整代码】
#include <cstdio>#include <cstdlib>#include <cmath>#include <set>#include <map>#include <iostream>#include <algorithm>#include <cstring>#include <queue>#include <vector>#include <stack>#include <string>using namespace std;#define lson l,m,rt<<1#define rson m+1,r,rt<<1|1#define LL long long#define rep1(i,a,b) for (int i = a;i <= b;i++)#define rep2(i,a,b) for (int i = a;i >= b;i--)#define mp make_pair#define pb push_back#define fi first#define se secondtypedef pair<int,int> pii;typedef pair<LL,LL> pll;void rel(LL &r){ r = 0; char t = getchar(); while (!isdigit(t) && t!='-') t = getchar(); LL sign = 1; if (t == '-')sign = -1; while (!isdigit(t)) t = getchar(); while (isdigit(t)) r = r * 10 + t - '0', t = getchar(); r = r*sign;}void rei(int &r){ r = 0; char t = getchar(); while (!isdigit(t)&&t!='-') t = getchar(); int sign = 1; if (t == '-')sign = -1; while (!isdigit(t)) t = getchar(); while (isdigit(t)) r = r * 10 + t - '0', t = getchar(); r = r*sign;}//const int MAXN = x;const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};const double pi = acos(-1.0);LL sqr(LL x){ return x*x;}LL k;int main(){ // freopen("F:\\rush.txt","r",stdin); cin >> k; LL a = 1,b = 1,c; while ((a+b)<=k) { c = a+b; a = b; b = c; } cout << "m="<<a<<endl; cout << "n="<<b<<endl; return 0;}
0 0
- 【9308】极值问题
- 极值问题
- 极值问题
- vijosP1543 极值问题
- [数学] NOI1995 极值问题
- 1543.极值问题
- 非线性约束极值问题
- 极值问题(dp)
- [笔记] RMQ区间极值问题
- 极值问题('95NOI试题)
- 无约束问题的极值条件
- 多元函数求极值问题
- 无约束极值问题的解法
- 多元函数求极值问题
- 多元函数求极值问题
- 约束极值问题/非线性规划问题
- MATLAB 无约束一维极值问题
- 拉格朗日乘数法解带约束的极值问题
- Hive的几种数据导入方式
- storm消费kafka数据
- pow(x,n)的实现
- 学习笔记——ng2基本架构
- 第十五周 项目一 - 验证算法
- 【9308】极值问题
- 如何过滤多余的cpu支持文件
- php中Session使用方法详解
- 过滤器(Filter)应用之------设置页面缓存、用户的自动登录和敏感词过滤
- QListWidget列表控件
- 传球游戏 tyvj1008(动态规划)
- hdu 1130 How Many Trees? (java)
- Java学习(一)
- 三分法查找