【usaco】1.1
你的飞碟在这儿Your Ride Is Here(难度:入门难度)
题目大意
emmmm 输入两个字符串,问他们每个字母的asco码相乘后字符串是否相等。
思路
一道水题?(雾)
错误代码:
#include<cstdio>
#include<cstring>
using namespace std;
char s1[10],s2[10];
int main()
{
scanf(" %s %s", s1+1,s2+1);
int len1=strlen(s1+1),len2=strlen(s2+1);
int ans1=1,ans2=1;
for(int i=1;i<=len1;i++)
ans1*=(s1[i]-'A'+1)%47;
for(int i=1;i<=len2;i++)
ans2*=(s2[i]-'A'+1)%47;
if(ans1==ans2)
printf("GO");
else
printf("STAY");
return 0;
}
注意ans1和ans2最后没有%47,所以最后的答案全部输出STAY,50分。
代码
#include<cstdio>
#include<cstring>
using namespace std;
char s1[10],s2[10];
int main()
{
scanf(" %s %s", s1+1,s2+1);
int len1=strlen(s1+1),len2=strlen(s2+1);
int ans1=1,ans2=1;
for(int i=1;i<=len1;i++)
ans1*=((s1[i]-64)%47);
for(int i=1;i<=len2;i++)
ans2*=((s2[i]-64)%47);
ans1%=47;
ans2%=47;
if(ans1==ans2)
printf("GO");
else
printf("STAY");
return 0;
}
贪婪的送礼者Greedy Gift Givers(难度:普及-)
题目大意
在一个聚会上,人们互相赠送钱,问聚会结束后每个人分别少了多少钱或多了多少钱。
思路
边读入边记录每个人的钱数,用结构体表示每个人的名字和他的钱数。模拟。
错误代码:
无
代码
#include<cstdio>
#include<cstring>
using namespace std;
int n;
struct node{
char name[20];
int sum;
}student[20];
int main()
{
scanf("%d", &n);
for(int i=1;i<=n;i++)
scanf(" %s", student[i].name);
for(int i=1;i<=n;i++)
{
char s[20];
int idx,mon,cnt,mon_aq,mon_af,idx1;
scanf(" %s", s);
for(int j=1;j<=n;j++)
if(strcmp(s,student[j].name)==0)
{
idx=j;
break;
}
scanf("%d%d", &mon, &cnt);
if(cnt==0)
continue;
mon_aq=mon/cnt;
mon_af=mon_aq*cnt;
student[idx].sum-=mon_af;
for(int j=1;j<=cnt;j++)
{
scanf(" %s", s);
for(int k=1;k<=n;k++)
if(strcmp(s,student[k].name)==0)
{
idx1=k;
break;
}
student[idx1].sum+=mon_aq;
}
}
for(int i=1;i<=n;i++)
printf("%s %d\n", student[i].name,student[i].sum);
}
黑色星期五Friday the Thirteenth(难度:普及-)
题目大意
从1900年到1900+n-1的时候每个月的13号是星期几。最后输出7个数,表示星期几
思路
直接通过每个月分的天数来统计即可。
错误代码:
无
代码
#include<cstdio>
using namespace std;
int n,last=3;
int month[12]={31,31,28,31,30,31,30,31,31,30,31,30};
int ans[7];
int main()
{
scanf("%d", &n);
for(int i=1900;i<=1899+n;i++)
{
if(i%400==0 || (i%100!=0 && i%4==0))
month[2]=29;
for(int j=0;j<12;j++)
{
last=(last+month[j])%7;
ans[last]++;
}
month[2]=28;
}
for(int i=0;i<7;i++)
printf("%d ", ans[(i+6)%7]);
return 0;
}
坏掉的项链Broken Necklace(难度:普及-)
题目大意
从项链的两边开始收集同颜色的珠子直到你遇到一个不同的颜色珠子,在另一端做同样的事,问最多收多少珠子。
思路
把输入的字符串复制两边来模拟一个环形,然后枚举每个点。
错误代码:
代码
#include<cstdio>
#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
int n;
string s;
int calc(int idx)
{
int ans=0;
char a1=s[idx];
char a2=s[idx+1];
for(int i=idx;;i--)
{
if(s[i]==a1 || s[i]=='w')
ans++;
else
break;
}
for(int i=idx+1;;i++)
{
if(s[i]==a2 || s[i]=='w')
ans++;
else
break;
}
return ans;
}
int main()
{
scanf("%d", &n);
cin>>s;
s=s+s+s;
int ans=0;
for(int i=n;i<2*n;i++)
{
if(s[i]==s[i+1])
continue;
if(s[i]=='w')
{
s[i]='r';
ans=max(ans,calc(i));
s[i]='b';
ans=max(ans,calc(i));
s[i]='w';
}
ans=max(ans,calc(i));
}
ans=min(ans,n);
if(ans==0)
ans=n;
printf("%d", ans);
return 0;
}
【usaco】1.1的更多相关文章
- POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 【USACO】距离咨询(最近公共祖先)
POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 [USACO]距离咨询(最近公共祖先) Description F ...
- 1642: 【USACO】Payback(还债)
1642: [USACO]Payback(还债) 时间限制: 1 Sec 内存限制: 64 MB 提交: 190 解决: 95 [提交] [状态] [讨论版] [命题人:外部导入] 题目描述 &quo ...
- 1519: 【USACO】超级书架
1519: [USACO]超级书架 时间限制: 1 Sec 内存限制: 64 MB 提交: 1735 解决: 891 [提交] [状态] [讨论版] [命题人:外部导入] 题目描述 Farmer Jo ...
- Java实现【USACO】1.1.2 贪婪的礼物送礼者 Greedy Gift Givers
[USACO]1.1.2 贪婪的礼物送礼者 Greedy Gift Givers 题目描述 对于一群要互送礼物的朋友,你要确定每个人送出的礼物比收到的多多少(and vice versa for th ...
- 【CPLUSOJ】【USACO】【差分约束】排队(layout)
[题目描述] Robin喜欢将他的奶牛们排成一队.假设他有N头奶牛,编号为1至N.这些奶牛按照编号大小排列,并且由于它们都很想早点吃饭,于是就很可能出现多头奶牛挤在同一位置的情况(也就是说,如果我们认 ...
- 【USACO】Dining
[题目链接] [JZXX]点击打开链接 [caioj]点击打开链接 [算法] 拆点+网络流 [代码] #include<bits/stdc++.h> using namespace std ...
- 【USACO】Optimal Milking
题目链接 : [POJ]点击打开链接 [caioj]点击打开链接 算法 : 1:跑一遍弗洛伊德,求出点与点之间的最短路径 2:二分答案,二分”最大值最小“ 3.1:建边,将 ...
- 【USACO】 Balanced Photo
[题目链接] 点击打开链接 [算法] 树状数组 [代码] #include<bits/stdc++.h> using namespace std; int i,N,ans,l1,l2; ] ...
- 【USACO】 Balanced Lineup
[题目链接] 点击打开链接 [算法] 这是一道经典的最值查询(RMQ)问题. 我们首先想到线段树.但有没有更快的方法呢?对于这类问题,我们可以用ST表(稀疏表)算法求解. 稀疏表算法.其实也是一种动态 ...
- 【USACO】The Cow Prom
[题目链接] 点击打开链接 [算法] tarjan求强连通分量 [代码] #include<bits/stdc++.h> #define MAXN 20005 using namespac ...
随机推荐
- JQuery总结摘要
一 概述 1.JQuery是什么? JQuery是一个JavaScript库,简化了JS操作,扩展了JS功能. 2.分离原则 JQuery遵循导入与使用分离的原则,即使用一个<script> ...
- 表单校验常用原生js库
1.字符串去除左右空格继承形式// 除去左右空格String.prototype.Trim = function() { return this.replace(/(^\s*)|(\s*$)/g, & ...
- Java设计模式—观察者模式
观察者模式(Observer Pattern)也叫做发布订阅模式(Publish/subscribe). 其定义如下: 定义对象间一种一对多的依赖关系,使得每当一个对象改变状态,则所有依赖于它的对象都 ...
- 05_dubbo_aop
[对这行代码进行源码分析] ExtensionLoader<Protocol> loader = ExtensionLoader.getExtensionLoader(Protocol.c ...
- 02_NIO简单实例
[一个用NIO实现的客户端向服务端单向通信的例子] [服务端程序] package com.nio.test; import java.io.IOException; import java.net. ...
- Data Flow ->> Source ->> Error Output ->> Error & Truncation: Ignore Failure, Redirect Now, Fail Component
Ignore Failure: 当该字段遇到错误时,字段值被设为NULL Redirect Now: 把该行输出到SSIS的Source组件的红色输出线,这时红色输出线应该连接一个可以接受结果集的组件 ...
- UVaOJ 694 - The Collatz Sequence
题目很简单,但是一开始却得到了Time Limit的结果,让人感到很诧异.仔细阅读发现,题目中有一个说明: Neither of these, A or L, is larger than 2,147 ...
- 一句DOS命令搞定文件合并
用Dos的copy命令实现: copy a.js+b.js+c.js abc.js /b 将 a.js b.js c.js 合并为一个 abc.js,最后的 /b 表示文件为二进位文件,copy 命令 ...
- 浅谈js冒泡事件1
什么是JS事件冒泡?: 在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这 ...
- 【深入理解JAVA虚拟机】第5部分.高效并发.2.线程安全和锁优化
1 概述 对于这部分的主题“高效并发”来讲,首先需要保证并发的正确性,然后在此基础上实现高效. 2 线程安全 <Java Concurrency In Practice> 的作者Brian ...