又落下好多题解啊。。。先把今天的写上好了。

A - Snow Footprints

Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u

Description

There is a straight snowy road, divided into n blocks. The blocks are numbered from 1 to n from left to right. If one moves from the i-th block to the (i + 1)-th block, he will leave a right footprint on the i-th block. Similarly, if one moves from the i-th block to the (i - 1)-th block, he will leave a left footprint on the i-th block. If there already is a footprint on the i-th block, the new footprint will cover the old one.

At the beginning, there were no footprints. Then polar bear Alice starts from the s-th block, makes a sequence of moves and ends in the t-th block. It is known that Alice never moves outside of the road.

You are given the description of Alice's footprints. Your task is to find a pair of possible values of s, t by looking at the footprints.

Input

The first line of the input contains integer n (3 ≤ n ≤ 1000).

The second line contains the description of the road — the string that consists of n characters. Each character will be either "." (a block without footprint), or "L" (a block with a left footprint), "R" (a block with a right footprint).

It's guaranteed that the given string contains at least one character not equal to ".". Also, the first and the last character will always be ".". It's guaranteed that a solution exists.

Output

Print two space-separated integers — the values of s and t. If there are several possible solutions you can print any of them.

Sample Input

Input
9
..RRLL...
Output
3 4
Input
11
.RRRLLLLL..
Output
7 5

Hint

The first test sample is the one in the picture.

题目很简单啦,就是给一串足迹,输出一组可能的起始终止的坐标。值得注意的是,本题只有3种情况,全R 全L 有R有L 在第三种情况里只有R在(且全在)L右边的情况。(只有向右走后才有向左走的权利)只输出一种结果就好了。

#include<stdio.h>
int main()
{
char s[];
int n,i,a,b;
int flag = ,m = ,num = ;
scanf("%d",&n);
char c = getchar();//直接getchar的话出了错误source code error,但是又交了一次却对了
scanf("%c",&s[]);
for(i = ;i < n;i++)
{
scanf("%c",&s[i]);
if(s[i] != '.')
{
num ++;
if(m == )m = i;
if(s[i - ] != '.'&&flag == && s[i] != s[i - ])flag = ;
}
}
if(flag == )
{
if(s[m] == 'R')
{
a = m + ;
b = a + num;
}
if(s[m] == 'L')
{
b = m;
a = b + num;
}
}
else
{
for(i = m;s[i] != '.' && i < n;i++)
{
if(s[i] == 'L')
{
a = m+;
b = i;
break;
}
}
}
printf("%d %d\n",a,b);
return ;
}
B - Sail

Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u

Description

The polar bears are going fishing. They plan to sail from (sx, sy) to (ex, ey). However, the boat can only sail by wind. At each second, the wind blows in one of these directions: east, south, west or north. Assume the boat is currently at (x, y).

  • If the wind blows to the east, the boat will move to (x + 1, y).
  • If the wind blows to the south, the boat will move to (x, y - 1).
  • If the wind blows to the west, the boat will move to (x - 1, y).
  • If the wind blows to the north, the boat will move to (x, y + 1).

Alternatively, they can hold the boat by the anchor. In this case, the boat stays at (x, y). Given the wind direction for t seconds, what is the earliest time they sail to (ex, ey)?

Input

The first line contains five integers t, sx, sy, ex, ey (1 ≤ t ≤ 105,  - 109 ≤ sx, sy, ex, ey ≤ 109). The starting location and the ending location will be different.

The second line contains t characters, the i-th character is the wind blowing direction at the i-th second. It will be one of the four possibilities: "E" (east), "S" (south), "W" (west) and "N" (north).

Output

If they can reach (ex, ey) within t seconds, print the earliest time they can achieve it. Otherwise, print "-1" (without quotes).

Sample Input

Input
5 0 0 1 1
SESNW
Output
4
Input
10 5 3 3 6
NENSWESNEE
Output
-1

Hint

In the first sample, they can stay at seconds 1, 3, and move at seconds 2, 4.

In the second sample, they cannot sail to the destination.

又是一道很简单的题呀,可是却一直wa啊,原来是一个比较简单的地方疏忽了。题的意思是船的行走有四个方向,每次走1(可以不走),给出起点和终点,及每秒的风向。输出到达目的地的最少时间,若不能到达,输出-1.我的方法是,因为船只能走折线到达目的地,根据起末位置确定是N(S)W(E)需要出现的次数即可。

#include<stdio.h>
int main()
{
int t,sx,sy,ex,ey;
char str[];
scanf("%d%d%d%d%d",&t,&sx,&sy,&ex,&ey);
scanf("%s",str);
int i,n = ,s = ,e = ,w = ;
if(ex - sx < )w = sx - ex;
else e = ex - sx;
if(ey - sy < )s = sy - ey;
else n = ey - sy;
int N = ,S = ,E = ,W = ;
if((s == && n == ) &&( w == && e == ))
{
printf("0\n");
return ;
}
for(i = ;i< t;i++)
{
if(str[i] == 'N'&& n != && N < n)N++;//一开始就是因为没有N < n的条件就一直错。原因是N的次数已经达到条件时若其他条件还未完成N就还会增加,这样肯定就没有结果了
else if(str[i] == 'S' && s!= && S < s)S++;
else if(str[i] == 'E' && e != && E < e)E++;
else if(str[i] == 'W'&& w != && W < w)W++;
if((S == s && W == w)&&( E == e&& N == n)){printf("%d\n",i+);return ;}
}
printf("-1\n");
return ;
}
D - Fish Weight

Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u

Description

It is known that there are k fish species in the polar ocean, numbered from 1 to k. They are sorted by non-decreasing order of their weight, which is a positive number. Let the weight of the i-th type of fish be wi, then 0 < w1 ≤ w2 ≤ ... ≤ wk holds.

Polar bears Alice and Bob each have caught some fish, and they are guessing who has the larger sum of weight of the fish he/she's caught. Given the type of the fish they've caught, determine whether it is possible that the fish caught by Alice has a strictly larger total weight than Bob's. In other words, does there exist a sequence of weights wi (not necessary integers), such that the fish caught by Alice has a strictly larger total weight?

Input

The first line contains three integers n, m, k (1 ≤ n, m ≤ 105, 1 ≤ k ≤ 109) — the number of fish caught by Alice and Bob respectively, and the number of fish species.

The second line contains n integers each from 1 to k, the list of fish type caught by Alice. The third line contains m integers each from 1 to k, the list of fish type caught by Bob.

Note that one may have caught more than one fish for a same species.

Output

Output "YES" (without quotes) if it is possible, and "NO" (without quotes) otherwise.

Sample Input

Input
3 3 3
2 2 2
1 1 3
Output
YES
Input
4 7 9
5 2 7 3
3 5 2 7 3 8 7
Output
NO

Hint

In the first sample, if w1 = 1, w2 = 2, w3 = 2.5, then Alice has a total of 2 + 2 + 2 = 6 weight units, while Bob only has 1 + 1 + 2.5 = 4.5.

In the second sample, the fish that Alice caught is a subset of Bob's. Therefore, the total weight of Bob’s fish is always not less than the total weight of Alice’s fish.

题意是有很多不同种类的鱼,种类用实数代表,题目给出的是鱼的种类数,(质量可以任意定,符合规则就好)相同种类的鱼质量相同,不同种类的鱼随着种类数的递增,质量也递增(相同也行)给出A,B两人所捕的鱼的情况,判断是否可能始A的鱼的总重量  绝对  大于B的鱼的总重量。

我的思路是这样的,若A的鱼的个数大于B的话一定可能(YES),因为可以始所有鱼的重量相同。若A鱼的个数不必B多的话,使A的总重量大于B就有很多种情况了,讨论起来太不方便。但反过来想,使B的总重量小于A的情况只有一种,那就是A中所有鱼的种类都小于或等于B的种类(换句话说,就是对于A中的所有种类,总能在B中找到比A种类大的)。

#include <algorithm>
#include <iostream>
using namespace std;
int a[],b[];
int main()
{
int n,m,k;
int j,i;
int flag = ;
cin>>n>>m>>k;
for( i=;i<n;i++)
cin >> a[i];
for( i=;i<m;i++)
cin >> b[i];
sort(a,a+n);
sort(b,b+m);
if(n > m)cout << "YES\n";
else
{
for(i = ,j = ;i<n && j < m;)
{
if(a[i] <= b[j])
{
i++;
j++;
}
else j++;
}
if(i==n ) cout<<"NO\n";
else cout << "YES\n";
}
return ;
}

OUC_Summer Training_ DIV2_#14 724的更多相关文章

  1. OUC_Summer Training_ DIV2_#16 725

    今天做了这两道题真的好高兴啊!!我一直知道自己很渣,又贪玩不像别人那样用功,又没有别人有天赋.所以感觉在ACM也没有学到什么东西,没有多少进步.但是今天的B题告诉我,进步虽然不明显,但是只要坚持努力的 ...

  2. OUC_Summer Training_ DIV2_#13 723afternoon

    A - Shaass and Oskols Time Limit:2000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I ...

  3. OUC_Summer Training_ DIV2_#12(DP1) 723

    这一次是做练习,主要了解了两个算法,最大子矩阵和,最长上升子序列. 先看题好啦. A - To The Max Time Limit:1000MS     Memory Limit:32768KB   ...

  4. OUC_Summer Training_ DIV2_#2之解题策略 715

    这是第一天的CF,是的,我拖到了现在.恩忽视掉这个细节,其实这一篇只有一道题,因为这次一共做了3道题,只对了一道就是这一道,还有一道理解了的就是第一篇博客丑数那道,还有一道因为英语实在太拙计理解错了题 ...

  5. OUC_Summer Training_ DIV2_#7 718

    是18号做的题啦,现在才把报告补上是以前不重视报告的原因吧,不过现在真的很喜欢写报告,也希望能写一些有意义的东西出来. A - Dragons Time Limit:2000MS     Memory ...

  6. OUC_Summer Training_ DIV2_#11 722

    企鹅很忙系列~(可惜只会做3道题T_T) A - A Time Limit:2000MS     Memory Limit:262144KB     64bit IO Format:%I64d &am ...

  7. OUC_Summer Training_ DIV2_#9 719

    其实自己只会做很简单的题,有时都不想写解题报告,觉得不值得一写,但是又想到今后也许就不会做ACM了,能留下来的东西只有解题报告了,所以要好好写,很渣的题也要写,是今后的纪念. B - B Time L ...

  8. OUC_Summer Training_ DIV2_#5

    这是做的最好的一次了一共做了4道题  嘻嘻~ A - Game Outcome Time Limit:2000MS     Memory Limit:262144KB     64bit IO For ...

  9. OUC_Summer Training_ DIV2_#4之数据结构

    http://acm.hust.edu.cn/vjudge/contest/view.action?cid=26100#problem/A A - A Time Limit:1000MS     Me ...

随机推荐

  1. 小程序wxs价格显示小数点后两位

    function toFix(data, val) { var numbers = ''; for (var i = 0; i < val; i++) { numbers += '0'; } v ...

  2. 微信小程序上传图片更新图像

    解决思路: 1. 调用wx.chooseImage 选择图片 2.wx.uploadFile 上传图片 3.调用后台接口进行修改操作 修改原来的头像 wx.chooseImage({ success: ...

  3. 使用postman创建Marketing Cloud的Contact

    首先在Marketing Cloud的UI上创建一个contact: 观察Chrome开发者工具network标签页里的HTTP请求: https://jerry.gcdemo.hybris.com/ ...

  4. JAVA栅栏和闭锁的区别

    闭锁:一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待.即,一组线程等待某一事件发生,事件没有发生前,所有线程将阻塞等待:而事件发生后,所有线程将开始执行:闭锁最初 ...

  5. c# MVC方式文件上传

    MVC控制器中代码 index.cshtml <form action="/Home/Upload" method="post" enctype=&quo ...

  6. Python学习记录7-继承

    面向对象的三大特性 封装 继承 多态 封装 封装就是对对象的成员进行访问限制 封装的三个级别: 公开,public 受保护的,protected 私有的,private public,private, ...

  7. Samba服务器配置案例

      一.项目背景 某公司有system.develop.productdesign和test等4个小组,个人办公机操作系统为Windows 2000/XP/2003,少数开发人员采用Linux操作系统 ...

  8. H2数据库启动提示8082端口被占用

    The Web Console server could not be started. Possible cause: another server is already running at ht ...

  9. Ubuntu系统---安装思维导图XMind

    Ubuntu系统---安装思维导图XMind @wp20181011 XMind安装很简单,这里简单记录记录一下.分为三步:1,下载.2,安装.3,设置桌面快捷图标. 详细步骤如下: 1,下载. 首先 ...

  10. git 版本落后推送错误

     http://114.215.90.144/student_association/student.git ! [rejected]        master -> master (non- ...