2017ICPC沈阳区域赛 F

简介: 2017ICPC沈阳区域赛 F


这题目有点恶心,推出来公式:

s = t ∗ ( s q r t ( 3 ∗ ( t − 2 ) ∗ ( t + 2 ) ) / 4 s=t*(sqrt(3*(t-2)*(t+2))/4s=t(sqrt(3(t2)(t+2))/4

通过 打表知道规律:

ans[i]=4*ans[i-1]-ans[i-2];

因为数据4–10^30 3030

所以用高精度或者int128;

高精度代码:

#include<bits/stdc++.h>
using namespace std;
const int N=1100;
vector<int>ans[N];
string n;
int T;
vector<int> sub(vector<int>a,vector<int>b)
{
  int t=0;
  vector<int>res;
  for(int i=0;i<a.size();i++)
  {
    t=a[i]-t;
    if(i<b.size()) t-=b[i];
    res.push_back((t+10)%10);
    if(t<0) t=1;
    else t=0; 
  }
  while(res.size()>1&&res.back()==0) res.pop_back();
  return res;
}
vector<int>mul(vector<int>&a,int b)
{
  int t=0;
  vector<int>res;
  for(int i=0;i<a.size()||t;i++)
  {
    if(i<a.size()) t+=a[i]*b;
    res.push_back(t%10);
    t/=10;
  }
  while(res.size()>1&&res.back()==0) res.pop_back();
  return res;
}
bool compare(vector<int>&a,vector<int>&now)
{
  if(a.size()!=now.size()) return a.size()<now.size();
  for(int i=a.size()-1;i>=0;i--)
  {
    if(a[i]<now[i]) return 1;
    else if(a[i]>now[i]) return 0;
  }
  return 0;
}
int main()
{
  cin>>T;
  ans[1].push_back(4);
  ans[2].push_back(4);
  ans[2].push_back(1);
  for(int i=3;i<=105;i++)
  {
    ans[i]=sub(mul(ans[i-1],4),ans[i-2]);
  }
  while(T--)
  {
      cin>>n;
      vector<int>now;
      for(int i=n.size()-1;i>=0;i--) now.push_back(n[i]-'0');
      int i=1;
      while(compare(ans[i],now))
      {
        i++;
      }
      for(int j=ans[i].size()-1;j>=0;j--)
      {
        cout<<ans[i][j];
      }
      cout<<endl;
  }
  return 0;
}

__int128版本:

#include<bits/stdc++.h>
using namespace std;
const int N=1100;
__int128 f[N],n;
int T;
__int128 read() {
  __int128 x = 0, f = 1;
  char ch = getchar();
  while (!isdigit(ch) && ch != '-')ch = getchar();
  if (ch == '-')f = -1;
  while (isdigit(ch))x = x * 10 + ch - '0', ch = getchar();
  return f * x;
}
inline void print(__int128 x) {
  if (x < 0) {
    putchar('-');
    x = -x;
  }
  if (x > 9) print(x / 10);
  putchar(x % 10 + '0');
}
int main()
{
  cin>>T;
  f[1]=4;
  f[2]=14;
  for(int i=3;i<=105;i++)
  {
    f[i]=4*f[i-1]-f[i-2];
  }
  while(T--)
  {
    n=read();
    int i=1;
    while(f[i]<n) i++;
      print(f[i]);
      cout<<"\n";
  }
  return 0;
}
目录
相关文章
|
1天前
|
存储 JavaScript 前端开发
JavaScript基础
本节讲解JavaScript基础核心知识:涵盖值类型与引用类型区别、typeof检测类型及局限性、===与==差异及应用场景、内置函数与对象、原型链五规则、属性查找机制、instanceof原理,以及this指向和箭头函数中this的绑定时机。重点突出类型判断、原型继承与this机制,助力深入理解JS面向对象机制。(238字)
|
2天前
|
安全 数据可视化 网络安全
安全无小事|阿里云先知众测,为企业筑牢防线
专为企业打造的漏洞信息收集平台
1302 2
|
3天前
|
云安全 人工智能
2025,阿里云安全的“年度报告”
拥抱AI时代,阿里云安全为你护航~
1447 2
|
10天前
|
机器学习/深度学习 安全 API
MAI-UI 开源:通用 GUI 智能体基座登顶 SOTA!
MAI-UI是通义实验室推出的全尺寸GUI智能体基座模型,原生集成用户交互、MCP工具调用与端云协同能力。支持跨App操作、模糊语义理解与主动提问澄清,通过大规模在线强化学习实现复杂任务自动化,在出行、办公等高频场景中表现卓越,已登顶ScreenSpot-Pro、MobileWorld等多项SOTA评测。
1417 7
|
11天前
|
人工智能 Rust 运维
这个神器让你白嫖ClaudeOpus 4.5,Gemini 3!还能接Claude Code等任意平台
加我进AI讨论学习群,公众号右下角“联系方式”文末有老金的 开源知识库地址·全免费
1300 16
|
5天前
|
人工智能 前端开发 API
Google发布50页AI Agent白皮书,老金帮你提炼10个核心要点
老金分享Google最新AI Agent指南:让AI从“动嘴”到“动手”。Agent=大脑(模型)+手(工具)+协调系统,可自主完成任务。通过ReAct模式、多Agent协作与RAG等技术,实现真正自动化。入门推荐LangChain,文末附开源知识库链接。
508 119
|
1天前
|
人工智能 自然语言处理 API
n8n:流程自动化、智能化利器
流程自动化助你在重复的业务流程中节省时间,可通过自然语言直接创建工作流啦。
305 3
n8n:流程自动化、智能化利器
|
3天前
|
机器学习/深度学习 测试技术 数据中心
九坤量化开源IQuest-Coder-V1,代码大模型进入“流式”训练时代
2026年首日,九坤创始团队成立的至知创新研究院开源IQuest-Coder-V1系列代码大模型,涵盖7B至40B参数,支持128K上下文与GQA架构,提供Base、Instruct、Thinking及Loop版本。采用创新Code-Flow训练范式,模拟代码演化全过程,提升复杂任务推理能力,在SWE-Bench、LiveCodeBench等基准领先。全阶段checkpoint开放,支持本地部署与微调,助力研究与应用落地。
402 1
|
2天前
|
安全 API 开发者
手把手带你使用无影 AgentBay + AgentScope 完成一站式智能体开发部署
阿里云无影 AgentBay 作为一个面向 AI 智能体开发的云端 GUI 沙箱服务,已集成至阿里巴巴通义实验室开源的 AgentScope 框架,助力开发者快速构建安全、高效的智能体应用。
237 1

热门文章

最新文章