T2】寻宝

读懂题目!!

是逆时针,第几个有钥匙的房间,还有能够直接上楼的是作为第一个有钥匙的房间,而不是就从这里直接上楼了

#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<stack>
#include<cstdio>
#include<queue>
#include<map>
#include<vector>
#include<set>
using namespace std;
const int maxn=1010;
const int INF=0x3fffffff;
int n,m;
//发现了我的一个错误点,我以为房间是按照顺时针排的,数的时候是逆时针,所以数的时候是--。。。。。
//另外发现了,,,我的代码真的不简洁完美,还欠缺气候,,很多地方值得改进
struct node{
int num;
int flag;
};
node ve[10001][110];
int isok[10010]; int main(){
scanf("%d %d",&n,&m);
int f,x,fir;
for(int i=1;i<=n;i++){
for(int j=0;j<m;j++){
scanf("%d %d",&ve[i][j].flag,&ve[i][j].num);
if(ve[i][j].flag) isok[i]++;
}
}
scanf("%d",&fir); long long ans=ve[1][fir].num%20123;
//long long summ=ans;
// cout<<summ<<endl;
// int flagg=ve[1][fir].flag;
int la=1,nex,op;
while(1){
op=(ve[la][fir].num-1)%isok[la]+1; //还需要走的,直接模取,不然肯定超时呀(另外这种写法,,,呜呜呜呜不错
int last=0;
while(last<op){
last+=ve[la][fir].flag;
if(last==op) break;
fir++;
if(fir==m) fir=0; //注意
}
la++;
ans=(ans+ve[la][fir].num)%20123;
if(la==n) break;
}
printf("%lld\n",ans%20123);
return 0;
}

  

T3】摆花

一开始拿到手没什么思路

结果其实就是DP

注意这个三重循环,一开始初值是f[0][0]=1

循环是:

for(int i=1;i<=n;i++)

for(int j=0;j<=m;j++)

for(int k=0;k<=a[i];k++)

if(j>=k)  注意这里

f[i][j]=(f[i][j]+f[i-1][j-k])%mod

#include<cstdio>
int f[101][101],n,m,a[101];
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]);
f[0][0]=1;
for(int i=1;i<=n;i++)
for(int j=0;j<=m;j++)
for(int k=0;k<=a[i];k++)
if(j>=k)
f[i][j]=(f[i][j]+f[i-1][j-k])%1000007;
printf("%d",f[n][m]);
}

  

T4】文化之旅

很简单,数据范围不大,floyd即可

#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<stack>
#include<cstdio>
#include<queue>
#include<map>
#include<vector>
#include<set>
using namespace std;
const int maxn=1010;
const int INF=10000000;
int n,k,m,s,t;
//数据不大,可以用暴力
int c[110][110];
int ctr[110];
int dis[110][110];
int main(){
cin>>n>>k>>m>>s>>t;
for(int i=1;i<=n;i++){
cin>>ctr[i];
}
int x,y,diss;
for(int i=1;i<=k;i++){
for(int j=1;j<=k;j++){
cin>>c[i][j];
}
}
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++) {
dis[i][j]=INF;
if(i==j) dis[i][j]=0;
}
for(int i=1;i<=m;i++){
cin>>x>>y>>diss;
dis[x][y]=min(dis[x][y],diss);
dis[y][x]=min(dis[y][x],diss); //因为有多条路 }
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(c[ctr[i]][ctr[j]]) dis[j][i]=INF; //i仇视j的文化,那么从j不可能去i,但是i可以去j
}
}
for(int k=1;k<=n;k++){ //之间的放外层
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
//if(i!=j&&i!=k&&j!=k)
dis[i][j]=min(dis[i][j],dis[i][k]+dis[k][j]);
}
}
}
if(dis[s][t]>=INF) cout<<"-1"<<endl;
else cout<<dis[s][t]<<endl;
return 0;
}

  

NOIP2012普及组的更多相关文章

  1. NOIP2012 普及组真题 4.13校模拟

    考试状态: 我今天抽签看了洛谷的… 这我能怂???凶中带吉,我怕考试??我!不!怕! 看着整个机房的男同学们,我明白我是不会触发我的忌了.很好,开刷. A. [NOIP2012普及组真题] 质因数分解 ...

  2. NOIP2012 普及组 T3 摆花——S.B.S.

    题目描述 小明的花店新开张,为了吸引顾客,他想在花店的门口摆上一排花,共m盆.通过调查顾客的喜好,小明列出了顾客最喜欢的n种花,从1到n标号.为了在门口展出更多种花,规定第i种花不能超过ai盆,摆花时 ...

  3. NOIP2012普及组 (四年后的)解题报告 -SilverN

    本章施工仍未完成 现在的时间是3.17 0:28,我困得要死 本来今天(昨天?)晚上的计划是把整个四道题的题解写出来,但是到现在还没写完T4的高效算法,简直悲伤. 尝试了用floyd写T4,终于大功告 ...

  4. [Noip2012普及组]摆花

    Description 小明的花店新开张,为了吸引顾客,他想在花店的门口摆上一排花,共 m 盆.通过调查顾客的喜好,小明列出了顾客最喜欢的 n 种花,从 1 到 n 标号.为了在门口展出更多种花,规定 ...

  5. 洛谷P1077 [NOIP2012普及组]摆花 [2017年四月计划 动态规划14]

    P1077 摆花 题目描述 小明的花店新开张,为了吸引顾客,他想在花店的门口摆上一排花,共m盆.通过调查顾客的喜好,小明列出了顾客最喜欢的n种花,从1到n标号.为了在门口展出更多种花,规定第i种花不能 ...

  6. [NOIP2012] 普及组

    寻宝 大模拟 #include<iostream> #include<cmath> #include<algorithm> using namespace std; ...

  7. noip2012普及组——质因数分解

    [问题描述]已知正整数 n 是两个不同的质数的乘积,试求出较大的那个质数. [输入]输入文件名为 prime.in.输入只有一行,包含一个正整数 n. [输出]输出文件名为 prime.out.输出只 ...

  8. NOIP2012 普及组 寻宝

    题目描述 Description 传说很遥远的藏宝楼顶层藏着诱人的宝藏.小明历尽千辛万苦终于找到传说中的这个藏宝楼,藏宝楼的门口竖着一个木板,上面写有几个大字:寻宝说明书.说明书的内容如下: 藏宝楼共 ...

  9. 【NOIP2012普及组】寻宝

    这道实际难度入门的题做得真™要麻烦死我,由于摸不到电脑,在大脑里调了3天都翻不转!! P1076 寻宝 思路:暴力模拟(这是基础,单纯暴力据说会全部TLE)+取模优化(这样时间复杂度骤降到O(NM)) ...

  10. 【NOIP2012普及组】质因数分解

    P1075 质因数分解 假期第一天就给一道入门难度的题写题解…… 这道题一开始就被我想复杂了:埃式筛,欧拉筛……然而开一个1e9的数组?不现实. 直到看到题解区的dalao用唯一分解定理: 算术基本定 ...

随机推荐

  1. 【小记】copy 与 copy_backward

    copy 与 copy_backward copy 从前往后复制,result 参数指向目标容器的 begin 位置 copy*backward 从后往前复制,··· end 位置 Possible ...

  2. @JsonSerialize(using = ToStringSerializer.class) 转换失败

    解决方案 但实际开发过程中,数据库的bigint,Java的Long都是比较常用的数据类型,为了避免精度丢失,针对这种比较大的数值 全局配置,将数值类型转换为文本如果需要将所有的数值类型全部转换成文本 ...

  3. HTML学习笔记1----HTML是什么

    随笔记录方便自己和同路人查阅. #------------------------------------------------我是可耻的分割线--------------------------- ...

  4. stream 链式结构 求和

    Double aDouble = Optional.ofNullable(wayfairMonthBill.getPaymentAmountDetailJson()) .filter(StringUt ...

  5. Word05 邀请函office真题

    1.课程的讲解之前,先来对题目进行分析,首先需要制作一份请柬,请柬中需要包含标题.收件人名称.联谊会时间.联谊会地点和邀请人. 2.打开一个"新的Wrod"文档,在页面中输入请柬的 ...

  6. Java流程控制之DoWhile循环

    DoWhile循环 对于while语句而言,如果不满足条件,则不能进入循环.但有时候我们需要即使不满足条件,也至少执行一次. do...while 循环和 while循环相似,不同的是,do...wh ...

  7. Web Dynpro for ABAP(16):WDA Analysis Tools

    3.21 Quality Assurance and Supportability WDA程序效能验证工具. Tests工具: eCATT and Web Dynpro ABAP Debugging工 ...

  8. 杭电oj 水仙花数

    Problem Description 春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的:"水仙花数"是指一个三位数,它的各位数字的立方和等于其本身 ...

  9. flask-基础篇02 请求与响应

    一.处理请求 1.URL路径参数(动态路由) # 例如,有一个请求访问的接口地址为/users/123,其中123实际上为具体的请求参数,表明请求123号用户的信息.此时如何从url中提取出123的数 ...

  10. Linux服务器中了挖矿木马怎么办?-挖矿木马自助清理手册

    什么是挖矿木马 挖矿木马会占用CPU进行超频运算,从而占用主机大量的CPU资源,严重影响服务器上的其他应用的正常运行.黑客为了得到更多的算力资源,一般都会对全网进行无差别扫描,同时利用SSH爆破和漏洞 ...