【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 ...
随机推荐
- MySQL数据库(5)----删除或更新已有行
有时候,会需要删除某些行,或者修改其内容.这是候便需要用到DELETE语句和UPDATE语句. 1. DELETE 语句的基本格式如下所示: DELETE FROM tbl_name WHERE wh ...
- 大V云集!参加首届阿里巴巴在线技术峰会的八大理由
由阿里巴巴集团.阿里巴巴技术协会(ATA)和阿里云云栖社区联合举办的首届阿里巴巴在线技术峰会(Alibaba Online Technology Summit)将于7月19日-21日20:00-21: ...
- 139.00.003 Git学习-Git时光机之Inbox体系(三)
一.Git时光机之Inbox 体系 工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库. Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有G ...
- 十五、css3 Filter--滤镜
如何实现下图的效果-—这里就用到了滤镜 给灰色弹框这个标签元素加“伪类”如下: #nearStoreContent .popChoose li:before { 1. z-index:; 2. pos ...
- C++ *this与this的区别(系个人转载,个人再添加相关内容)
转载地址:http://blog.csdn.net/stpeace/article/details/22220777 return *this返回的是当前对象的克隆或者本身(若返回类型为A, 则是克隆 ...
- Session和Cookie详解(1)
面试常问的有关session和cookie的问题: 1.session在分布式环境下怎么解决 2.集群下如何保证session踩中 3.cookie的大小 4.服务器怎么识别一个用户的 5.sessi ...
- Java任务调度框架Quartz入门
Quartz[kwɔːts]:石英,其框架和名字一样简单朴素又不失魅力,在Java程序界,Quartz大名鼎鼎,很多Java应用几乎都集成或构建了一个定时任务调度系统,Quartz是一个定时任务调度框 ...
- SQL Server ->> Database Snapshot(数据块快照)
Comming soon!!! 参考文献: View the Size of the Sparse File of a Database Snapshot 数据库快照 (SQL Server) 创建数 ...
- cocos2d-x 的api
最近,在学习cocos2d-x,发现没有一个很好的api手册.因为起初我们学习一些例子之类的内容,会很容易使用,也很容易明白,但是当我们需要用新的api的时候,第一就会疑问有没有这个api,比如:你使 ...
- C# 转换运算符:implicit(隐式),explicit(显示)
//A类 class Cls1 { public string name; //构造函数 public Cls1(string name) { this.name = name; } //implic ...