个人背景:

上午9:30放学,然后因为学校举办读书工程跟同学去书城选书,中午回来开始打比赛,下午又回老家,中间抽出一点时间调代码,回家已经8:50了

也许是7月月赛时“连蒙带骗”AK的太幸运然而因同学的id评测过判代码雷同扣100分后while(true) rp--;本次是一个凄惨.....

我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了

我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了

我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了

我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了

我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了

我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了我太弱了

-------------------------------------------------------------------------

题目:

http://scarlet.is-programmer.com/user_files/Scarlet/File/COOL's%20Life.pdf

--------------------------------------------------

过程:

第一题在去书城的公交车上就开始想,对于需要快速找到行x,y坐标都大的点,分别找x和y然后取交集怎么样?貌似还是n^2

唉,范围20*20的方格,可以每个宿舍保存在哪里的妹子啊,那样n*400

然后,调试时出现迷之问题,用了vector二维数组,好像是溢出或是什么问题,造数据的循环卡在刚结束,怎么搞都不好

【2016-08-12在win下测试,把频繁的debug输出该少些,n=90000也出结果了,但很慢,洛谷仍re】

至少会了double取模 呵呵呵

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<algorithm>
  4. #include<vector>
  5. #include<cmath>
  6. #include<cstring>
  7. using namespace std;
  8. typedef long double ld;
  9. const int N=,rp=;
  10.  
  11. int n,cnt=;
  12. double rxa,rxc,rya,ryc,rza,rzc;
  13. double ans=;
  14. vector<int> map[][]; //num
  15. //int map2[21][21][N];
  16. struct people{
  17. double x,y;
  18. int i,j;
  19. people(){x=;y=;i=;j=;}
  20. //int num;
  21. }p[N];
  22.  
  23. double dmod(double x,int m){
  24. int t=x;
  25. int j=t/m;
  26. return x-j*m;
  27. }
  28. void init(){
  29. double x=,y=,z=;
  30. for(int i=;i<=n;i++){
  31. x=dmod((y*rxa+rxc),rp);
  32. y=dmod((z*rya+ryc),rp);
  33. z=dmod((x*rza+rzc),rp);
  34. p[i].x=dmod(x,)+dmod(y,)/+dmod(z,)/; p[i].i=p[i].x;
  35.  
  36. x=dmod((y*rxa+rxc),rp);
  37. y=dmod((z*rya+ryc),rp);
  38. z=dmod((x*rza+rzc),rp);
  39. p[i].y=dmod(x,)+dmod(y,)/+dmod(z,)/; p[i].j=p[i].y;
  40.  
  41. //if(i>89000||i%1000==0) printf("%d i %d j %d\n",i,p[i].i,p[i].j);
  42. map[p[i].i][p[i].j].push_back(i);
  43. //printf("%d %lf %lf\n",i,p[i].x,p[i].y);printf("hello");
  44. }
  45. return;
  46. }
  47.  
  48. inline double cal(people &a,people &b){
  49. return fabs(a.x-b.x)+fabs(a.y-b.y);
  50. }
  51.  
  52. void solve(){
  53. for(int i=;i<=n;i++){
  54. people &now=p[i];//if(i>89000||i%1000==0) printf(" i %d\n",i);
  55. for(int x=now.i+;x<;x++)
  56. for(int y=now.j+;y<;y++)
  57. for(int z=;z<map[x][y].size();z++){
  58. ans+=cal(now,p[map[x][y][z]]); cnt++;
  59. }
  60. }
  61. }
  62.  
  63. int main(){//system("pause");
  64. cin>>n;
  65. cin>>rxa>>rxc>>rya>>ryc>>rza>>rzc;
  66. init();
  67.  
  68. //cout<<"p";
  69. solve();
  70. if(cnt==) printf("0.00000");
  71. printf("%.5f",ans/cnt);
  72.  
  73. //cout<<"\n\n";
  74. //for(int i=1;i<=n;i++) printf("p %d %lf %lf %d %d\n",i,p[i].x,p[i].y,p[i].i,p[i].j);
  75. }

用正解的思路写了一遍,依旧30,好像init()就一直不对

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<algorithm>
  4. #include<vector>
  5. #include<cmath>
  6. #include<cstring>
  7. using namespace std;
  8. typedef long double ld;
  9. const int N=,rp=;
  10.  
  11. int n,cnt=;
  12. double rxa,rxc,rya,ryc,rza,rzc;
  13. double ans=;
  14.  
  15. struct node{
  16. int num;
  17. double sum;
  18. node(int a=,double b=):num(a),sum(b){}
  19. };
  20. node map[][];
  21.  
  22. struct people{
  23. double x,y;
  24. int i,j;
  25. people(){x=;y=;i=;j=;}
  26. //int num;
  27. }p[N];
  28.  
  29. double dmod(double x,int m){
  30. int t=x;
  31. int j=t/m;
  32. return x-j*m;
  33. }
  34. void init(){
  35. double x=,y=,z=;
  36. for(int i=;i<=n;i++){
  37. x=dmod((y*rxa+rxc),rp);
  38. y=dmod((z*rya+ryc),rp);
  39. z=dmod((x*rza+rzc),rp);
  40. p[i].x=dmod(x,)+dmod(y,)/+dmod(z,)/; p[i].i=p[i].x;
  41.  
  42. x=dmod((y*rxa+rxc),rp);
  43. y=dmod((z*rya+ryc),rp);
  44. z=dmod((x*rza+rzc),rp);
  45. p[i].y=dmod(x,)+dmod(y,)/+dmod(z,)/; p[i].j=p[i].y;
  46.  
  47. map[p[i].i][p[i].j].num++; map[p[i].i][p[i].j].sum+=p[i].x-p[i].i+p[i].y-p[i].j;
  48. // printf("%d i %d j %d sum %f\n",i,p[i].i,p[i].j,map[p[i].i][p[i].j].sum);
  49. }
  50. return;
  51. }
  52.  
  53. void solve(){
  54. for(int i=;i<;i++)
  55. for(int j=;j<;j++){
  56. for(int ni=i+;ni<;ni++)
  57. for(int nj=j+;nj<;nj++){
  58. node &node1=map[i][j],&node2=map[ni][nj];
  59. //if(node1.num||node2.num)printf("map %d %f %d %f\n",node1.num,node1.sum,node2.num,node2.sum);
  60. cnt+=node1.num*node2.num;
  61. ans+=node1.num*node2.num*(ni-i+nj-j)-node2.num*node1.sum+node1.num*node2.sum;
  62. // printf("ans %.5f\n",ans);
  63. }
  64. }
  65. }
  66. int main(){//system("pause");
  67. cin>>n;
  68. cin>>rxa>>rxc>>rya>>ryc>>rza>>rzc;
  69. init();
  70. solve();
  71. //printf("%f %d\n",ans,cnt);
  72.  
  73. printf("%.5f",ans/cnt);
  74.  
  75. //cout<<"p";
  76.  
  77. //cout<<"\n\n";
  78. //for(int i=1;i<=n;i++) printf("p %d %lf %lf %d %d\n",i,p[i].x,p[i].y,p[i].i,p[i].j);
  79. }

第二题,数学。

我只想到了对于每个数根号n枚举约数快速幂暴力,预处理前缀和,当l==r时改为直接算f(i)

莫名其妙给快速幂加了个记忆化,最终骗了40分

  1. //
  2. // main.cpp
  3. // luogu8_2
  4. //
  5. // Created by abc on 16/8/11.
  6. // Copyright © 2016年 abc. All rights reserved.
  7. //
  8.  
  9. #include <iostream>
  10. #include <cstdio>
  11. #include <cstring>
  12. #include <algorithm>
  13. #include <cmath>
  14. using namespace std;
  15. typedef long long ll;
  16. const int MOD=1e9+,N=1e7+;
  17. inline ll read(){
  18. char c=getchar(); ll x=,f=;
  19. while(c<''||c>''){if(c=='-')f=-;c=getchar();}
  20. while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
  21. return x;
  22. }
  23.  
  24. ll n,d,q,l,r;
  25. ll f[N],s[N];
  26.  
  27. ll pm[N];
  28. inline ll powMod(ll a,ll b){
  29. if(pm[a]) return pm[a]; ll t=a;
  30. ll ans=;
  31. for(;b;b>>=,a=(a*a)%MOD)
  32. if(b&) ans=(ans*a)%MOD;
  33. return pm[t]=ans;
  34. }
  35.  
  36. inline ll divisorPow(ll x){
  37. if(f[x]) return f[x];
  38. int m=sqrt(x+0.5);
  39. ll ans=; //
  40. for(int i=;i<=m;i++) if(x%i==){
  41. ans=(ans+powMod(i,d))%MOD;
  42. if(i*i!=x) ans=(ans+powMod(x/i,d))%MOD;
  43. }
  44. if(x!=) ans=(ans+powMod(x,d))%MOD;
  45. return f[x]=ans;
  46. }
  47.  
  48. bool flag=;
  49. void init(){
  50. if(flag) return;
  51. flag=;
  52. for(int i=;i<=n;i++){
  53. f[i]=divisorPow(i);s[i]=(s[i-]+f[i])%MOD;
  54. }
  55. }
  56.  
  57. int main(int argc, const char * argv[]) {
  58. n=read();d=read();
  59. q=read();
  60. for(int i=;i<=q;i++){
  61. l=read();r=read();
  62. if(l==r) printf("%lld\n",divisorPow(l));
  63. else{init();printf("%lld\n",(s[r]-s[l-]+MOD)%MOD);}
  64. }
  65. //cout<<f[719]<<" "<<f[720]<<" "<<s[720];
  66. return ;
  67. }

第三题,关于树,想了想,可以枚举神秘对象,然后对于他枚举所有链,利用lca统计经过他的链(具体方法见代码),排下序取最大最小值即可。

复杂度O(n*m*logn) 要排序和用lca

然而只拿三十分,感觉n=5000,m=500也可以过啊?难道是rp

洛谷八月月赛Round1凄惨记的更多相关文章

  1. 洛谷八月月赛 II T2 题解

    Content 现有 \(T\) 次询问. 每次询问给定一个长度为 \(n\) 的 01 串,记为 \(A\).回答应是一个字符串 \(B\),满足: \(B\) 是长度为 \(m\) 的 01 串. ...

  2. 洛谷八月月赛 II T1 题解

    Content 在大小为 \(n\) 的数字三角形中,第 \(i\) 行包含有 \(i\) 个数字,数字从上到下,从左到右依次排列为 \(1,2,3,\dots\). 设第 \(i\) 行第 \(j\ ...

  3. 洛谷五月月赛【LGR-047】划水记

    虽然月赛有些爆炸,但我永远资瓷洛谷! 因为去接水,所以迟到了十几分钟,然后洛谷首页就打不开了-- 通过洛谷题库间接打开了比赛,看了看\(TA\),WTF?博弈论?再仔细读了读题,嗯,判断奇偶性,不过要 ...

  4. 洛谷P2110 欢总喊楼记

    洛谷题目链接 乱搞qwq 我们其实可以找规律,对于每个数$x$,我们先求出从$1$~$x$中有多少符合条件的,记为$sum[x]$,那么类似于前缀和,答案自然就是$sum[r]-sum[l-1]$了 ...

  5. uoj233/BZOJ4654/洛谷P1721 [Noi2016]国王饮水记 【dp + 斜率优化】

    题目链接 uoj233 题解 下面不加证明地给出几个性质: 小于\(h[1]\)的城市一定是没用的 任何城市联通包含\(1\)且只和\(1\)联通一次 联通顺序从小到大最优 单个联通比多个一起联通要优 ...

  6. 洛谷⑨月月赛Round2 P3393逃离僵尸岛[最短路]

    题目描述 小a住的国家被僵尸侵略了!小a打算逃离到该国唯一的国际空港逃出这个国家. 该国有N个城市,城市之间有道路相连.一共有M条双向道路.保证没有自环和重边. K个城市已经被僵尸控制了,如果贸然闯入 ...

  7. 洛谷⑨月月赛Round2 P3392涂国旗[DP]

    题目描述 某国法律规定,只要一个由N*M个小方块组成的旗帜符合如下规则,就是合法的国旗.(毛熊:阿嚏——) 从最上方若干行(>=1)的格子全部是白色的. 接下来若干行(>=1)的格子全部是 ...

  8. 5239-回忆京都-洛谷3月赛gg祭

    传送门 题目背景 第十五届东方人气投票 音乐部门 106名 第四次国内不知道东方的人对东方原曲的投票调查 51名 回忆京都副歌我tm吹爆,东方文花帖我tm吹爆! 题目描述 射命丸文在取材中发现了一个好 ...

  9. 5238-整数校验器-洛谷3月赛gg祭

    传送门 题目描述 有些时候需要解决这样一类问题:判断一个数 x是否合法. x合法当且仅当其满足如下条件: x格式合法,一个格式合法的整数要么是 0,要么由一个可加可不加的负号,一个 1到 9 之间的数 ...

随机推荐

  1. 根据网址把图片下载到服务器C#代码

    根据网址把图片下载到服务器C#代码 ASPX页面代码: <%@ Page Language="C#" AutoEventWireup="true" Cod ...

  2. 【追寻javascript高手之路02】变量、作用域知多少?

    前言 本来想把这个与上篇博客写到一起的,但是考虑到是两个知识点还是分开算了,于是我们继续今天的学习吧. 基本类型与引用类型 ECMAScript的的变量有两种类型: 基本类型(值类型):简单数据段 引 ...

  3. js动态计算移动端rem

    在做移动端web app的时候,众所周知,移动设备分辨率五花八门,虽然我们可以通过CSS3的media query来实现适配,例如下面这样: html { font-size : 20px; } @m ...

  4. ORA-00054:资源正忙,但指定以nowait方式

    PL/SQL执行SQL脚本文件,报错如下: 百度寻找答案,认为是被锁了. select session_id from v$locked_object; 结果没有任何数据.   后来把PL/SQL关闭 ...

  5. inputType属性

    android中inputType属性在EditText输入值时启动的虚拟键盘的风格有着重要的作用.这也大大的方便的操作.有时需要虚拟键盘只为字符或只为数字.所以inputType尤为重要.<E ...

  6. [Android]使用Kotlin开发Android(二)

    以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/4829007.html [TOC] 使用Kotlin+OkHtt ...

  7. iOS设置文字过长时的显示格式

    以label为例: //设置文字过长时的显示格式 aLabel.lineBreakMode = UILineBreakModeMiddleTruncation; //截去中间 aLabel.lineB ...

  8. iOS tableviewcell 分割线 偏移和颜色

    改变颜色 [_hotProductsTableView setSeparatorColor : kSeparatorColor]; -(void)viewDidLayoutSubviews { [su ...

  9. Swift中的部分更新与旧版的区别

    1. 函数中的外部变量名取消 “#”方式,仅能用直接命名方式 错误 func swift(#str :NSString){} 正确 func swift(str str :NSString){} 2. ...

  10. eclipse中配置dtd和xsd文件实现自动提示

    DTD 类型约束文件      1. Window->Preferences->XML->XML Catalog->User Specified Entries窗口中,选择Ad ...