【五校联考1day2】JZOJ2020年8月12日提高组T1 对你的爱深不见底

题目

Description

出乎意料的是,幸运E 的小R 居然赢了那个游戏。现在欣喜万分的小R 想要写一张明信片给小Y,但是因为小R 非常羞涩,所以他打算采用一些比较神奇的方式来表达。

他定义了一些字符串,s1 = a,s2 = b,si =s_i-1 + s_i-2 (i >=3)。同时他定义了一个字符串s 的权值为一个最大的i <|s|满足s 长度为i 的前缀等于长度为i 的后缀。比如字符串aba 的权值就是1,abab 的权值就是2,aaaa 的权值就是3。

现在小R 在明信片上给出了两个数n 和m,他想要告诉小Y 的信息是字符串sn 的前m个字符组成的字符串的权值。你可以帮小Y 计算一下吗?

Input

第一行输入一个正整数T 表示数据组数。

对于每组数据,第一行是两个整数n;m。保证1<= m <=|sn|

Output

对于每组数据,输出一个整数表示答案。答案可能很大,你只需要输出模258280327 后的答案。

Sample Input

2

4 3

5 5

Sample Output

1

2

Data Constraint

对于30% 的数据,n <= 20

对于60% 的数据,n <= 60

对于100% 的数据,n <= 10^3,1 <= T <= 100

题解

题意

定义一些字符串,\(s_1=a\),\(s_2=b\),\(s_i=s_{i-1}+s_{i-2}\)(例如\(s_3\)是\(ba\))

问\(s_n\)的前\(m\)个字符的权值

权值定义:对于一个字符串,前缀和后缀的相同部分的长度

分析

通过打表发现规律

找到一个最小\(n\)满足

\(|s[n]|>m+1\)

那么答案就是\(m-|s[n-2]|\)

那么直接求解即可,用高精度

Code

#include<cstdio>
#include<cstring>
#include<algorithm>
#define mod 258280327
using namespace std;
struct gjd
{
int a[505],len;
}f[10005],Ans;
int n,k,i,t,l,r,mid,ans,dr[10005];
char ch;
bool judge(gjd &x,gjd &y)
{
int i;
if (x.len<y.len) return true;
if (x.len>y.len) return false;
for (i=x.len;i;i--)
{
if (x.a[i]<y.a[i]) return true;
if (x.a[i]>y.a[i]) return false;
}
return false;
}
void fibonacci(gjd &a,gjd &b,gjd &c)
{
int i;
for (i=1;i<=c.len;i++)
c.a[i]=0;
c.len=0;
for (i=1;i<=a.len||i<=b.len;i++)
{
c.a[i]+=a.a[i]+b.a[i];
c.a[i+1]+=c.a[i]/10;
c.a[i]%=10;
}
c.len=max(a.len,b.len);
while (c.a[c.len+1])
{
c.len++;
c.a[c.len+1]=c.a[c.len]/10;
c.a[c.len]%=10;
}
}
int main()
{
freopen("test.in","r",stdin);
freopen("test.out","w",stdout);
f[1].a[1]=1;
f[1].len=1;
f[2]=f[1];
for (i=3;i<=1001;i++)
fibonacci(f[i-2],f[i-1],f[i]);
scanf("%d",&t);
while (t--)
{
scanf("%d",&n);
Ans.len=0;
memset(Ans.a,0,sizeof(Ans.a));
ch=getchar();
while (ch<'0'||ch>'9') ch=getchar();
while (ch>='0'&&ch<='9')
{
Ans.len++;
dr[Ans.len]=ch-'0';
ch=getchar();
}
for (i=1;i<=Ans.len;i++)
Ans.a[Ans.len-i+1]=dr[i];
Ans.a[1]++;
for (i=1;i<=Ans.len;i++)
{
Ans.a[i+1]+=Ans.a[i]/10;
Ans.a[i]%=10;
}
if (Ans.a[Ans.len+1]) Ans.len++;
l=1;
r=1001;
k=0;
while (l<=r)
{
mid=(l+r)>>1;
if (judge(Ans,f[mid]))
{
k=mid;
r=mid-1;
}
else l=mid+1;
}
k-=2;
Ans.a[1]--;
for (i=1;i<=f[k].len;i++)
{
Ans.a[i]-=f[k].a[i];
if (Ans.a[i]<0)
{
Ans.a[i]+=10;
Ans.a[i+1]--;
}
}
while (!Ans.a[Ans.len]&&Ans.len>1) Ans.len--;
ans=0;
for (i=Ans.len;i;i--)
ans=((long long)ans*10+Ans.a[i])%mod;
printf("%d\n",ans);
}
return 0;
}

【五校联考1day2】JZOJ2020年8月12日提高组T1 对你的爱深不见底的更多相关文章

  1. 【五校联考1day2】JZOJ2020年8月12日提高组T2 我想大声告诉你

    [五校联考1day2]JZOJ2020年8月12日提高组T2 我想大声告诉你 题目 Description 因为小Y 是知名的白富美,所以自然也有很多的追求者,这一天这些追求者打算进行一次游戏来踢出一 ...

  2. JZOJ2020年8月11日提高组T1 密码

    JZOJ2020年8月11日提高组T1 密码 题目 Description 在浩浩茫茫的苍穹深处,住着上帝和他的神仆们,他们闲谈着下界的凡人俗事,对人世间表现的聪明智慧,大加赞赏.今天他们正在观赏大地 ...

  3. 【GDKOI2014】JZOJ2020年8月13日提高组T1 阶乘

    [GDKOI2014]JZOJ2020年8月13日提高组T1 阶乘 题目 Description Input 第一行有一个正整数T,表示测试数据的组数. 接下来的T行,每行输入两个十进制整数n和bas ...

  4. JZOJ2020年8月12日提高组反思

    JZOJ2020年8月12日提高组反思 真·难亿一点点 T1 题目长并附带伤害-- 暴力搜 对于字符串,我选择\(Pascal\) T2 概率问题,再见 T3 样例没懂,再见 T4 有史以来见过的条件 ...

  5. 【GDOI2007】JZOJ2020年8月10日提高组T1 夏娜的菠萝包

    [GDOI2007]JZOJ2020年8月10日提高组T1 夏娜的菠萝包 题目 Description 夏娜很喜欢吃菠萝包,她的经纪人RC每半个月就要为她安排接下来的菠萝包计划.今天是7月份,RC又要 ...

  6. 【NOIP2012模拟8.7】JZOJ2020年8月8日提高组T1 奶牛编号

    [NOIP2012模拟8.7]JZOJ2020年8月8日提高组T1 奶牛编号 题目 作为一个神秘的电脑高手,Farmer John 用二进制数字标识他的奶牛. 然而,他有点迷信,标识奶牛用的二进制数字 ...

  7. 【佛山市选2013】JZOJ2020年8月7日提高组T1 回文子序列

    [佛山市选2013]JZOJ2020年8月7日提高组T1 回文子序列 题目 描述 回文序列是指左右对称的序列.例如1 2 3 2 1是回文序列,但是1 2 3 2 2就不是.我们会给定一个N×M的矩阵 ...

  8. 【GDKOI2014】JZOJ2020年8月13日提高组T2 石油储备计划

    [GDKOI2014]JZOJ2020年8月13日提高组T2 石油储备计划 题目 Description Input Output 对于每组数据,输出一个整数,表示达到"平衡"状态 ...

  9. JZOJ2020年8月11日提高组T4 景点中心

    JZOJ2020年8月11日提高组T4 景点中心 题目 Description 话说宁波市的中小学生在镇海中学参加计算机程序设计比赛,比赛之余,他们在镇海中学的各个景点参观.镇海中学共有n个景点,每个 ...

随机推荐

  1. POJ1840 Eqs

    题意描述 Eqs 求一个五元方程 \(a_1x_1^3+a_2x_2^3+a_3x_3^3+a_4x_4^3+a_5x_5^3=0\) 的解的个数. 题中给出 \(a_i\) 的值并且保证 \(-50 ...

  2. 线上Java程序占用 CPU 过高,请说一下排查方法?

    我是风筝,公众号「古时的风筝」,一个兼具深度与广度的程序员鼓励师,一个本打算写诗却写起了代码的田园码农! 文章会收录在 JavaNewBee 中,更有 Java 后端知识图谱,从小白到大牛要走的路都在 ...

  3. leetcode117:search-rotated-sorted-array

    题目描述 给出一个转动过的有序数组,你事先不知道该数组转动了多少 (例如,0 1 2 4 5 6 7可能变为4 5 6 7 0 1 2). 在数组中搜索给出的目标值,如果能在数组中找到,返回它的索引, ...

  4. 数据治理方案技术调研 Atlas VS Datahub VS Amundsen

    数据治理意义重大,传统的数据治理采用文档的形式进行管理,已经无法满足大数据下的数据治理需要.而适合于Hadoop大数据生态体系的数据治理就非常的重要了. ​ 大数据下的数据治理作为很多企业的一个巨大的 ...

  5. 中科图新成为Bentley产品培训合作伙伴!质量服务双升级

    中科图新从2016年起开办ContextCapture产品培训,目前已累计培训了500多家企事业单位,涉及传统测绘单位.无人机航测.规划设计.建筑工程.水利.电力.交通.文保等十多个行业.实力过硬,口 ...

  6. 学习.NET 挑战赛

    今天访问dot.net 网站看到了一个学习.NET 挑战赛,发现已经赛程过半了,这是一个为那些想更多地了解 C# 和 .NET 的人举办的一个完全免费的课程活动,这些模块必须在 11 月底前完成.参加 ...

  7. 2. Hive常见操作命令整理

    该笔记主要整理了<Hive编程指南>中一些常见的操作命令,大致如下(持续补充中): 1. 查看/设置/修改变量2. 执行命令3. 搜索相关内容4. 查看库表信息5. 创建表6. 分区7. ...

  8. WIN10下安装python3.7.2出现“尝试创建C:\Users\XX\AppData\Roaming\Microsoft\Installer时出错”

    WIN10下安装python3.7.2出现"尝试创建C:\Users\XX\AppData\Roaming\Microsoft\Installer时出错" 1.右键点击安装包以管理 ...

  9. ceph打印出每秒的IO和pg状态

    前言 在ceph 的jewel版本以及之前的版本,通过ceph -w命令是可以拿到每秒钟ceph集群的io状态的,现在的版本是ceph -s一秒秒手动去刷,ceph -w也不监控io的状态了,有的时候 ...

  10. Python_获取cookie

    获取cookie from selenium import webdriver from selenium.webdriver.common.by import By # 定位 from seleni ...