今天比赛的时候拿到的第一道题,其实挺简单的,求两等差序列中相同元素的个数,我想了一下就觉得,只要找到了第一个相等的点,然后后面求最大公约数就可以直接得到结果了

网上叫什么拓展欧几里得,我反正是按照我们的思路来的

关键是如何找到第一个相等的点,因为首项和公差能达到 10^9,项数可以达到10^18,我觉得会不会第一个相等的点就直接爆了long long,不过在跟聪哥统一了一下意见之后,决定试一下,即先暴力找到第一个相等的点。。。

最后WA了。。。因为时间也不多了,而且我担心WA是不是因为我们相等的点已经爆了 unsighed long long 了。。。没想到是我代码写挫了,就是前期找第一个相等的点的时候写挫了。。次奥,这个题没在比赛的时候出了,全部责任在我。,。。。

我前期处理有点乱,其实就写个while(1)循环,唯一出口就是两个相等的时候,我还判断些什么取模是否相等,真是乱,哎

事实证明只要前期处理的好,就基本上没问题了

还有,其实觉得会爆的不如去做一做,最后其实结果可能就是你想的这样

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <cstring>
  4. #define ll unsigned long long
  5. using namespace std;
  6. struct node
  7. {
  8. ll n,f,d;
  9. }s[];
  10. ll gcd(ll a,ll b)
  11. {
  12. if (a<b) swap(a,b);
  13. return b==?a:gcd(b,a%b);
  14. }
  15. int main()
  16. {
  17. int t;
  18. scanf("%d",&t);
  19. while (t--){
  20. scanf("%llu%llu%llu",&s[].n,&s[].f,&s[].d);
  21. scanf("%llu%llu%llu",&s[].n,&s[].f,&s[].d);
  22. ll sum=;
  23. ll q1=s[].f,q2=s[].f;
  24. while (){ //前期处理得到第一个相等的数
  25. if (q1==q2){sum=q1;break;}
  26. if (q1<q2){
  27. ll tmp=(q2-q1)/s[].d;
  28. if (tmp==) tmp=;
  29. q1+=tmp*s[].d;
  30. if (q1<q2) q1+=s[].d;
  31. }
  32. else{
  33. ll tmp=(q1-q2)/s[].d;
  34. if (tmp==) tmp=;
  35. q2+=tmp*s[].d;
  36. if (q2<q1) q2+=s[].d;
  37. }
  38. }
  39. ll ans;
  40. ll num=gcd(s[].d,s[].d); //后期比较得到最多的相同的元素,最后要用min比较而不是max是因为要找到满足两个序列都有的最多的元素,不是单独一个序列最多就可以的
  41. ll dis=(sum-s[].f)/s[].d+;
  42. dis=s[].n-dis;
  43. ans=dis/(s[].d/num)+;
  44.  
  45. dis=(sum-s[].f)/s[].d+;
  46. dis=s[].n-dis;
  47. ans=min(ans,(dis/(s[].d/num))+);
  48. printf("%llu\n",ans);
  49. }
  50. return ;
  51. }

UVALive 6763 / CSU 1446的更多相关文章

  1. CSU 1446 Modified LCS 扩展欧几里得

    要死了,这个题竟然做了两天……各种奇葩的错误…… HNU的12831也是这个题. 题意: 给你两个等差数列,求这两个数列的公共元素的数量. 每个数列按照以下格式给出: N F D(分别表示每个数列的长 ...

  2. UVAlive 6763 Modified LCS

    LCS stands for longest common subsequence, and it is a well known problem. A sequence in thisproblem ...

  3. coderforces Gym 100803A/Aizu 1345/CSU 1536/UVALive 6832 Bit String Reordering(贪心证明缺)

    Portal: http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=1345  http://codeforces.com/gym/100 ...

  4. UVALive - 4108 SKYLINE[线段树]

    UVALive - 4108 SKYLINE Time Limit: 3000MS     64bit IO Format: %lld & %llu Submit Status uDebug ...

  5. UVALive - 3942 Remember the Word[树状数组]

    UVALive - 3942 Remember the Word A potentiometer, or potmeter for short, is an electronic device wit ...

  6. UVALive - 3942 Remember the Word[Trie DP]

    UVALive - 3942 Remember the Word Neal is very curious about combinatorial problems, and now here com ...

  7. csu 1812: 三角形和矩形 凸包

    传送门:csu 1812: 三角形和矩形 思路:首先,求出三角形的在矩形区域的顶点,矩形在三角形区域的顶点.然后求出所有的交点.这些点构成一个凸包,求凸包面积就OK了. /************** ...

  8. CSU 1503 点到圆弧的距离(2014湖南省程序设计竞赛A题)

    题目链接:http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1503 解题报告:分两种情况就可以了,第一种是那个点跟圆心的连线在那段扇形的圆弧范围内,这 ...

  9. CSU 1120 病毒(DP)

    题目链接:http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1120 解题报告:dp,用一个串去更新另一个串,递推方程是: if(b[i] > a ...

随机推荐

  1. [LeetCode] 326. Power of Three + 342. Power of Four

    这两题我放在一起说是因为思路一模一样,没什么值得研究的.思路都是用对数去判断. /** * @param {number} n * @return {boolean} */ var isPowerOf ...

  2. mysql5.7.26安装

    h https://www.cnblogs.com/zgqbky/p/11699282.html 张国强(明了) tar -xf mysql-5.7.26-1.el7.x86_64.rpm-bundl ...

  3. Echarts 折线图y轴标签值过长 显示

    参考: https://blog.csdn.net/dandelion_drq/article/details/79270597 改变Y轴单位:https://www.cnblogs.com/cons ...

  4. Activity的生命周期及协同作用

    生命周期 onCreate:创建Activity的实例对象的方法 onStart:启动当前的activity实例的方法 onResume:如果该方法执行,页面的实例和用户即可以交互 onPause:如 ...

  5. Windows编程常用api

    转载网络 黑客常用WIN API函数整理 一.进程 创建进程: CreateProcess (,,,,,,,&si,&pi); WinExec("notepad", ...

  6. SelectList类的构造函数

    SelectList类的构造函数 2016年05月23日 17:29:52 FrankyJson 阅读数 272 标签: MVC函数 更多 个人分类: MVC   SelectList 构造函数 (I ...

  7. 009.Oracle数据库 , between关键字判断日期在两者之间

    /*Oracle数据库查询日期在两者之间*/ SELECT PKID, OCCUR_DATE, ATA FROM LM_FAULT WHERE ( OCCUR_DATE BETWEEN to_date ...

  8. Quartus设计FIR滤波器的系数文件格式(适用于FIR II的IP核)

    对常用的FIR,我们使用MATLAB的fdatool(或者filterDesigner) 设计滤波器,给定指标,生成系数.为了方便,我们将系数保存到文件,其保存格式比较简介,在此进行说明. 1.FIR ...

  9. 如何禁用AD OU 下面的邮箱用户的Exchange ActiveSync 和 适用于设备的OWA

    Get-Mailbox -OrganizationalUnit QQ禁用名单 | Set-CASMailbox  -ActiveSyncEnabled $false -OWAforDevicesEna ...

  10. 四十一、在SAP中添加多条件选择框

    一.代码如下: 二.其中我们的文本替换内容如下 三.需要注意的是波浪线的用法,以及区域的添加方法.运行程序,显示如下 四.不勾选时,查询出来是去掉国际的 五.勾选之后,查询的是全部的 六.显示如下 七 ...