虽然有点久远  还是放一下吧。

传送门:https://www.luogu.org/contest/show?tid=754

第一题  沉迷游戏,伤感情

#include <queue>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std; long long t,n,ans,i,c[],last,now,sum[],s;
deque<long long> q; inline long long read()
{
long long ret=,iep=;char ch=getchar();
while (ch<'' || ch>'') {if (ch=='-') iep=-;ch=getchar();}
while (ch>=''&&ch<='') {ret=ret*+ch-'';ch=getchar();}
return ret;
} int main()
{
t=read();
while (t--)
{
n=read();ans=;memset(sum,,sizeof sum);
for (i=;i<=n;i++) s=read(),sum[i]=s+sum[i-];
q.clear();
for (i=;i<=n;i++)
{
c[i]=read();
while (!q.empty() && c[i]<=c[q.back()]) q.pop_back();
q.push_back(i);
}
last=;
while (!q.empty())
{
now=q.front();
q.pop_front();
ans+=(sum[now]-sum[last])*c[now];
last=now;
}
printf("%lld\n",ans);
}
}

第二题  精研白学,减智商

#include <cstdio>
#include <iostream>
#include <algorithm>
using namespace std; int n,m,t,x,y,last,i,k,tot;
double f[][],z,a[]; struct node{
int x,y;
double z;
}A[]; struct edge{
double s[][];
edge operator *(const edge &x) const
{
edge ret;
for (int i=;i<=n;i++)
for (int j=;j<=n;j++){
ret.s[i][j]=;
for (int k=;k<=n;k++)
ret.s[i][j]+=s[i][k] * x.s[k][j];
}
return ret;
}
}mat,map; inline int read()
{
int ret=,iep=;char ch=getchar();
while (ch<'' || ch>'') {if (ch=='-') iep=-;ch=getchar();}
while (ch>=''&&ch<='') {ret=ret*+ch-'';ch=getchar();}
return ret;
} int dfs()
{
last=;
for (i=;i<=n;i++) f[i][]=a[i];
for (i=;i<=n;i++) f[i][(last+)%]=;
for (i=;i<=tot;i++) f[A[i].y][(last+)%]+=f[A[i].x][last%]*map.s[A[i].y][A[i].x]*1.0;
} edge ksm(int x)
{
if (x==) return mat;
edge ret=ksm(x/);
ret=ret*ret;
if (x&) return ret*mat;
return ret;
} int doit()
{
last=;
for (i=;i<=n;i++) f[i][]=a[i];
for (k=;k<=t;k++)
{
for (i=;i<=n;i++) f[i][(last+)%]=;
for (i=;i<=tot;i++) f[A[i].y][(last+)%]+=f[A[i].x][last%]*A[i].z*1.0;
last++;
}
} int main()
{
n=read();m=read();t=read();tot=;
if (n<)
{
for (i=;i<=m;i++)
tot++,A[tot].x=read(),A[tot].y=read(),cin>>A[tot].z,mat.s[A[tot].y][A[tot].x]+=A[tot].z;
map=ksm(t);
for (i=;i<=n;i++) cin>>a[i];
dfs();last++;
for (i=;i<n;i++)
printf("%.6f ",f[i][last%]);
printf("%.6f\n",f[n][last%]);
}
else
{
for (i=;i<=m;i++)
tot++,A[tot].x=read(),A[tot].y=read(),cin>>A[tot].z;
for (i=;i<=n;i++) cin>>a[i];
doit();
for (i=;i<n;i++)
printf("%.6f ",f[i][last%]);
printf("%.6f\n",f[n][last%]);
}
return ;
}

Luogu 魔法学院杯-第二弹(萌新的第一法blog)的更多相关文章

  1. Unity萌新日记—开发小技巧与冷知识(脚本篇)

    在学习unity的过程中,总会遇到很多零碎的知识点和小技巧,在此把它们记录下来,方便日后查看. 第一篇是关于脚本的一些你可能不知道的小知识. 还是个正在学习的萌新,如果写的不好,请谅解. Unity版 ...

  2. 关于『HTML5』:第二弹

    关于『HTML5』:第二弹 建议缩放90%食用 咕咕咕咕咕咕咕!!1 (蒟蒻大鸽子终于更新啦) 自开学以来,经过了「一脸蒙圈的 半期考试」.「二脸蒙圈的 体测」的双重洗礼,我终于有空肝 HTML5 辣 ...

  3. 浅谈Hybrid技术的设计与实现第二弹

    前言 浅谈Hybrid技术的设计与实现 浅谈Hybrid技术的设计与实现第二弹 浅谈Hybrid技术的设计与实现第三弹——落地篇 接上文:浅谈Hybrid技术的设计与实现(阅读本文前,建议阅读这个先) ...

  4. 萌新笔记——C++里创建 Trie字典树(中文词典)(三)(联想)

    萌新做词典第三篇,做得不好,还请指正,谢谢大佬! 今天把词典的联想做好了,也是比较low的,还改了之前的查询.遍历等代码.  Orz 一样地先放上运行结果: test1 ID : char : 件 w ...

  5. 萌新笔记——C++里创建 Trie字典树(中文词典)(二)(插入、查找、导入、导出)

    萌新做词典第二篇,做得不好,还请指正,谢谢大佬! 做好了插入与遍历功能之后,我发现最基本的查找功能没有实现,同时还希望能够把内存的数据存入文件保存下来,并可以从文件中导入词典.此外,数据的路径是存在配 ...

  6. 萌新的IDEA_web开发笔记(未完)

    萌新IDEA_web开发笔记 按兴趣自己搞的网页: http://47.94.140.98:8080/ow_web/my_web/web/ 暂时还没做完. 部署在租的服务器上面,背景视频加载可能有点慢 ...

  7. 『PyTorch』第二弹重置_Tensor对象

    『PyTorch』第二弹_张量 Tensor基础操作 简单的初始化 import torch as t Tensor基础操作 # 构建张量空间,不初始化 x = t.Tensor(5,3) x -2. ...

  8. Trick and Magic(OO博客第二弹)

    代码是设计,不是简单的陈述.而设计不仅要求功能的正确性,更注重设计风格和模式. 真正可以投入应用的程序设计,不是那种无脑的“黑箱”,超巨大的数组,多重循环暴力搜索,成吨全局变量……事实上,在实际应用中 ...

  9. 高并发第二弹:并发概念及内存模型(JMM)

    高并发第二弹:并发概念及内存模型(JMM) 感谢 : 深入Java内存模型 http://www.importnew.com/10589.html, cpu缓存一致性 https://www.cnbl ...

随机推荐

  1. abrt-hook-ccpp: Saved core dump of pid 12224导致dn挂掉问题

    一.引言: 最近发现datanode老是无缘无故的进程挂掉,从程序的日志没有stop迹象,只能从/var/log/messages入手,发现如下信息: 从namenode的页面也可以看到进程消息的时间 ...

  2. Curling 2.0

    Description On Planet MM-21, after their Olympic games this year, curling is getting popular. But th ...

  3. c#实现邮件发送链接激活

    2016-08-24 10:09:52 public void MailSend(string email) { MailMessage MyMail = new MailMessage(); MyM ...

  4. HttpClient,DefaultHttpClient使用详解

    HttpClient:是一个接口 首先需要先创建一个DefaultHttpClient的实例 HttpClient httpClient=new DefaultHttpClient(); 发送GET请 ...

  5. 使用cocoaPods和遇到的问题以及解决办法

    上一篇说到cocoaPods的安装,本篇就来说说cocoaPods的使用和遇到一些问题的解决办法( ⊙ o ⊙ ) 一.cocoaPods的创建使用 1.cd进入所在的项目目录 2.创建Podfile ...

  6. [JAVA] java class 基本定义 Note

    java class 基本定义 Note 1 package abeen.note; 2 import java.util.*; 3 4 5 /* 6 java calss 基本 7 */ 8 pub ...

  7. C++多线程の条件变量

    如果有一个队列,方法一和方法二:方法一是生产者,方法二是消费者: 两者不停的相互等待,加减锁,为了减少不必要的等待,我们可以使用条件变量, 条件的变量的第二个参数的加入可以控制多个线程的"消 ...

  8. (转)sqlplus中文显示乱码的问题

    sqlplus中文显示乱码的问题 2010-07-19 11:33:26 分类: LINUX 在windows下sqlplus完全正常,可是到linux下,sqlplus中文显示就出问题了,总是显示“ ...

  9. 外媒速递:十大最佳心理学概念助你提升Web设计效果

    外媒速递是核子可乐精选的近日国外媒体的精彩文章推荐,希望大家喜欢! 本期给大家推荐的是帮助你提升Web设计效果的十大最佳心理学概念.改善企业云环境协作效率的九款卓越工具.选择移动应用开发工具时要考虑的 ...

  10. 29.Hadoop之HDFS集群搭建笔记

    0.修改IP,主机名,hosts文件         setup        修改网卡IP         service  network  restart        重启网络服务使IP生效 ...