“玲珑杯”ACM比赛 Round #23
Time Limit:2s Memory Limit:128MByte
Submissions:263Solved:97
给定一个整数n,输出[(10^n)/7]的个位数。
其中 abs(n) ≤ 1e18
接下来每一行一个整数n。
#include<bits/stdc++.h>
using namespace std;
string s="";
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
long long n;
cin>>n;
n--;
if(n<)
printf("0\n");
else
printf("%c\n",s[n%]);
}
Time Limit:2s Memory Limit:128MByte
Submissions:127Solved:86
给定一个99的数独,判断该数独是否合法。
如果合法输出Yes,否则输出No。
数独当且仅当每行每列以及9个33的小方格都是1〜9的9个数才合法。
两组数据之间没有空行。
保证输入的数独中的数都在1~9中。
B直接暴力判断
#include<bits/stdc++.h>
using namespace std;
int a[][];
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
int f=;
for(int i=; i<; i++)
for(int j=; j<; j++)
scanf("%d",&a[i][j]);
for(int i=; i<; i+=)
for(int j=; j<; j+=)
{
int b[]= {};
for(int k=i-; k<=i; k++)
for(int l=j-; l<=j; l++)
if(a[k][l]>&&a[k][l]<)b[a[k][l]]++;
for(int i=; i<; i++)
if(!b[i])f=;
}
printf("%s\n",f?"Yes":"No");
}
}
Time Limit:2s Memory Limit:128MByte
Submissions:131Solved:66
给定一个正整数n,现在有n个石头,每个单独成一堆。
现在可以每次合并两堆石头,产生的能量为两堆石头个数的min。
你现在要将所有的石头合并成一堆,并且获得的能量最大。
输出这个最大值。
1 ≤ n ≤ 1e7。
数据满足一个测试点中,最多只有1个n超过1e6。
C太暴力了我,用的是合并
#include<bits/stdc++.h>
using namespace std;
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
map<int,int>M;
int n,a,b,c,d;
scanf("%d",&n);
M[]=n;
long long ans=;
for(;;)
{
a=M.begin()->first,b=M.begin()->second;
if(b>)
{
ans+=b/*a;
M[a+a]=b/;
if(b&)M[a]=;
else M.erase(M.begin());
}
else if(b==)
{
if(M.size()==)break;
else
{
c=(++M.begin())->first,d=(++M.begin())->second;
ans+=a;
M[a+c]=;
M.erase(M.begin());
M[c]=d-;
}
}
else M.erase(M.begin());
if(!M.size())break;
}
printf("%lld\n",ans);
}
}
蓝金爷的直接分堆
#include<bits/stdc++.h>
using namespace std;
long long ans;
void dfs(int x)
{
if(x==)return;
ans+=x/,dfs(x/);
if(x&)dfs(x/+);
else dfs(x/);
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
int n;
cin>>n;
ans=;
dfs(n);
cout<<ans<<"\n";
}
}
TLE的直接优先队列(1e7我电脑要2s,优化下可以1s跑完,但是OJ没那么快啊
#include<bits/stdc++.h>
using namespace std;
priority_queue<int, vector<int>, greater<int> > Q;
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
while(!Q.empty())Q.pop();
int n;
scanf("%d",&n);
for(int i=;i<n;i++)
Q.push();
long long ans=;
while(Q.size()>=)
{
int a=Q.top();Q.pop();
int b=Q.top();Q.pop();
ans+=a;
Q.push(a+b);
}
printf("%lld\n",ans);
}
}
Time Limit:2s Memory Limit:128MByte
Submissions:25Solved:20
给定两个正整数 nn 和 kk, 请求出
∑x1=0 ∑x2=0...∑xn=0 x1+x2+...+xnkx1+x2+...+xn∑x1=0 ∑x2=0...∑xn=0 x1+x2+...+xnkx1+x2+...+xn
(如果公式看不懂,请看图)
数据保证答案是一个有理数,我们假设它为 pqpq , 你只需输出它对 1e9+71e9+7 的模即可。(即 p∗q−1p∗q−1 对 1e9+71e9+7 的模数)。
对于每组数据:
一行两个正整数,表示 nn 和 kk 。
数据满足 1<=T<=1000,1<=n<=1e9,2<=k<=1e91<=T<=1000,1<=n<=1e9,2<=k<=1e9 。
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int MD=1e9+;
LL po(LL a, LL n)
{
LL ans = ;
while(n)
{
if(n&) ans=(ans*a)%MD;
a=(a*a)%MD;
n>>=;
}
return(ans+MD)%MD;
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
LL n,k,a,b;
scanf("%lld%lld",&n,&k);
a=po(k,n)*n%MD;
b=po(k-,n+)%MD;
LL bn=po(b,MD-);
printf("%lld\n",(a*bn)%MD);
}
return ;
}
“玲珑杯”ACM比赛 Round #23的更多相关文章
- “玲珑杯”ACM比赛 Round #12题解&源码
我能说我比较傻么!就只能做一道签到题,没办法,我就先写下A题的题解&源码吧,日后补上剩余题的题解&源码吧! A ...
- “玲珑杯”ACM比赛 Round #19题解&源码【A,规律,B,二分,C,牛顿迭代法,D,平衡树,E,概率dp】
A -- simple math problem Time Limit:2s Memory Limit:128MByte Submissions:1599Solved:270 SAMPLE INPUT ...
- “玲珑杯”ACM比赛 Round #19 B -- Buildings (RMQ + 二分)
“玲珑杯”ACM比赛 Round #19 Start Time:2017-07-29 14:00:00 End Time:2017-07-29 16:30:00 Refresh Time:2017-0 ...
- “玲珑杯”ACM比赛 Round #1
Start Time:2016-08-20 13:00:00 End Time:2016-08-20 18:00:00 Refresh Time:2017-11-12 19:51:52 Public ...
- “玲珑杯”ACM比赛 Round #18
“玲珑杯”ACM比赛 Round #18 Start Time:2017-07-15 12:00:00 End Time:2017-07-15 15:46:00 A -- 计算几何你瞎暴力 Time ...
- “玲珑杯”ACM比赛 Round #1 题解
A:DESCRIPTION Eric has an array of integers a1,a2,...,ana1,a2,...,an. Every time, he can choose a co ...
- 玲珑杯”ACM比赛 Round #4 1054 - String cut 暴力。学到了扫描的另一种思想
http://www.ifrog.cc/acm/problem/1054 问删除一个字符后的最小循环节是多少. 比赛的时候想不出,不知道怎么暴力. 赛后看了别人代码才晓得.唉,还以为自己字符串还不错, ...
- “玲珑杯”ACM比赛 Round #18--最后你还是AK了(搜索+思维)
题目链接 DESCRIPTION INPUT OUTPUT SAMPLE INPUT 1 4 2 1 2 5 2 3 5 3 4 5 5 5 SAMPLE OUTPUT 35 HINT 对于样例, ...
- “玲珑杯”ACM比赛 Round #22 E 贪心,脑洞
1171 - 这个E大概是垃圾桶捡来的 Time Limit:2s Memory Limit:128MByte Submissions:138Solved:45 DESCRIPTION B君在做 CO ...
随机推荐
- MySQL查询示例
use test; create table t1(tid smallint(5) unsigned auto_increment,tname varchar(50),tkecheng varchar ...
- 洛谷 P2827 蚯蚓
题目描述 本题中,我们将用符号\lfloor c \rfloor⌊c⌋表示对c向下取整,例如:\lfloor 3.0 \rfloor= \lfloor 3.1 \rfloor=\lfloor 3.9 ...
- EF6.0注意事项
EF6 1.必须要添加Entitiframework 2.必须要添加必须要添加Entitiframework.Sqlserver 3.单元测试一定要有配置文件里面一定要有连接字符串和初始化配置文件节点 ...
- ubuntu 18.04下 配置qt opencv的坑
问题和过程描述: 我按照网上的教程装了qt5.8版本,然后去配置opencv,感觉一切顺利,然后随便写了个 Mat src = imread("xxx") 然后imshow发现编译 ...
- JavaScript实现页面到滚动到指定位置执行某些操作
比如 页面中 某个DOM, 希望点击按钮后页面直接跳转到 这个DOM所在的位置, 1. 获取DOM离屏幕的高度 var hTop = $('#box').offset().top; $('body,h ...
- 最全面的 python 字符串拼接总结(带注释版)
在 Python 中字符串连接有多种方式,这里简单做个总结,应该是比较全面的了,方便以后查阅. 加号连接 第一种,通过+号的形式: >>> a, b = 'hello', ' wor ...
- 【转】Intellij IDEA 提交代码到远程GitHub仓库
1.文章参考自:http://my.oschina.net/lujianing/blog/180728 2.设置相关绑定 Settings——Version Control——Git——Path to ...
- C#语言命名的9种规范
下面介绍C#语言命名的9种规范: a) 类 [规则1-1]使用Pascal规则命名类名,即首字母要大写. [规则1-2]使用能够反映类功能的名词或名词短语命名类. [规则1-3]不要使用“I”.“C” ...
- oracle中print_table存储过程实例介绍
oracle中pro_print_table存储过程实例介绍 存储过程(Stored Procedure),就是一组用于完成特定数据库功能的SQL语句集,该SQL语句集经过编译后存储在数据库系统中.这 ...
- 使用的是html5的canvas将文字转换成图片
当前功能的运用场景是:用户需要传文件给他人,在用户选择文件之后需要显示一个文件图标和所选文件的名称. 当前代码部分是摘自网上,但是已经忘记在什么地方获取的,如有侵权联系小弟后自当删除. 注意:必须在h ...