A

模拟题

#include <bits/stdc++.h>
#define PI acos(-1.0)
#define mem(a,b) memset((a),b,sizeof(a))
#define TS printf("!!!\n")
#define pb push_back
#define inf 1e9
//std::ios::sync_with_stdio(false);
using namespace std;
//priority_queue<int,vector<int>,greater<int>> que; get min
const double eps = 1.0e-10;
const double EPS = 1.0e-4;
typedef pair<int, int> pairint;
typedef long long ll;
typedef unsigned long long ull;
//const int maxn = 3e5 + 10;
const int maxn = ;
const int turn[][] = {{, }, { -, }, {, }, {, -}};
const int turn2[][] = {{, }, { -, }, {, }, {, -}, {, -}, { -, -}, {, }, { -, }};
//priority_queue<int, vector<int>, less<int>> que;
//next_permutation
int main()
{
double h, m, C;
cin >> h >> m;
int H, D, N;
cin >> H >> D >> C >> N;
double ans = ;
double duce = ;
if (h < )
{
duce = 1.0 * ( - h) * - m;
}
else
{
C = 0.8 * C;
}
int need = H / N + ( - (H % N == ));
double ans1 = 1.0 * need * C;
if (duce != )
{
H += D * duce;
C = 0.8 * C;
need = H / N + ( - (H % N == ));
ans = need * C;
printf("%.4f\n", min(ans, ans1));
}
else
{
printf("%.4f\n", ans1);
}
}

B

阅读理解

#include <bits/stdc++.h>
#define PI acos(-1.0)
#define mem(a,b) memset((a),b,sizeof(a))
#define TS printf("!!!\n")
#define pb push_back
#define inf 1e9
//std::ios::sync_with_stdio(false);
using namespace std;
//priority_queue<int,vector<int>,greater<int>> que; get min
const double eps = 1.0e-10;
const double EPS = 1.0e-4;
typedef pair<int, int> pairint;
typedef long long ll;
typedef unsigned long long ull;
//const int maxn = 3e5 + 10;
const int turn[][] = {{, }, { -, }, {, }, {, -}};
//priority_queue<int, vector<int>, less<int>> que;
//next_permutation
int ch[];
int main()
{
int sum = ;
string a;
cin >> a;
for (int i = ; i < a.size(); i++)
{
if (ch[a[i] - 'a'] == )
{
sum++;
}
ch[a[i] - 'a']++;
}
if (sum > )
{
cout << "No" << endl;
return ;
}
if (sum == )
{
cout << "Yes" << endl;
}
else if (sum == )
{
for (int i = ; i <= ; i++)
{
if (ch[i] > )
{
cout << "Yes" << endl;
return ;
}
}
cout << "No" << endl;
}
else if (sum == )
{
for (int i = ; i <= ; i++)
{
if (ch[i] == )
{
cout << "No" << endl;
return ;
}
}
cout << "Yes" << endl;
}
else
{
cout << "No" << endl;
}
return ;
}

C

给你Q(1~1e5)个询问 每个询问有L,R(1~1e18)

问你L~R之间有多少个"good number"  “good number"是a^p的数 a>0 p>1

因为总共有1e18个数 所以当p固定时 就有10^(18/p)个数 当p为2的时候很大 特殊处理 二分枚举checkL和R的sqrt得到答案

再来处理3~60部分(因为2^60>1e18)的答案 因为最大的10^(18/3)只有1e6所以可以全部枚举出来再nlogn排序去重 预处理复杂度为nlogn

#include <bits/stdc++.h>
#define PI acos(-1.0)
#define mem(a,b) memset((a),b,sizeof(a))
#define TS printf("!!!\n")
#define pb push_back
#define inf 1e9
//std::ios::sync_with_stdio(false);
using namespace std;
//priority_queue<int,vector<int>,greater<int>> que; get min
const double eps = 1.0e-10;
typedef pair<int, int> pairint;
typedef long long ll;
typedef unsigned long long ull;
//const int maxn = 3e5 + 10;
const int maxn = ;
const int turn[][] = {{, }, { -, }, {, }, {, -}};
const int turn2[][] = {{, }, { -, }, {, }, {, -}, {, -}, { -, -}, {, }, { -, }};
//priority_queue<int, vector<int>, less<int>> que;
//next_permutation
ll nowmaxn = 1e18;
ll anser1;
ll anser2;
ll num[];
int pop = ;
//ll qpow(ll a, ll b)
//{
// ll ans = 1, base = a;
// while (b != 0)
// {
// if (b & 1 != 0)
// {
//   ans *= base;
// }
// base *= base;
// b >>= 1ll;
//  
// }
// return ans;
//}
bool judge(ll x)
{
ll s = sqrt(x);
for (ll i = s; i <= s + ; i++)
{
if (1LL * i * i == x)
{
return true;
}
}
return false;
}
void init()
{
ll now;
ll limit;
for (ll i = ; i <= ; i++)
{
limit = nowmaxn / i;
now = 1LL * i * i;
for (ll j = ;; j++)
{
now = 1LL * i * now;
if (!judge(now))
{
num[pop++] = now;
}
if (now > limit)
{
break;
}
}
}
sort(num + , num + pop);
pop = unique(num + , num + pop) - num;
}
ll gettwo(ll x)
{
ll ans;
ll l = ;
ll r = 2e9;
while (l < r - )
{
ll mid = (l + r) >> ;
if (mid * mid <= x)
{
l = mid;
}
else
{
r = mid;
}
}
return l;
}
int main()
{
init();
// for (int i = 1; i <= 10; i++)
// {
// cout << num[i] << " ";
// }
// cout << endl;
ll L, R;
int q;
cin >> q;
for (int i = ; i <= q; i++)
{
anser1 = anser2 = ;
scanf("%lld %lld", &L, &R);
if (L == )
{
anser1++;
}
anser1 = gettwo(R) - gettwo(L - );
//cout << anser1 << endl;
int L1 = lower_bound(num + , num + pop, L) - num;
int R1 = lower_bound(num + , num + pop, R) - num;
//cout << " " << L1 << " " << R1 << endl;
if (L1 == R1)
{
if (num[L1] == R)
{
anser2++;
}
}
else
{
anser2 = R1 - L1 + (num[R1] == R);
}
cout << anser1 + anser2 << endl;
}
}

Codeforces 955 LR询问 多次幂处理的更多相关文章

  1. codeforces magic five --快速幂模

    题目链接:http://codeforces.com/contest/327/problem/C 首先先算出一个周期里面的值,保存在ans里面,就是平常的快速幂模m做法. 然后要计算一个公式,比如有k ...

  2. CodeForces - 691E Xor-sequences 【矩阵快速幂】

    题目链接 http://codeforces.com/problemset/problem/691/E 题意 给出一个长度为n的序列,从其中选择k个数 组成长度为k的序列,因为(k 有可能 > ...

  3. Codeforces 963 A. Alternating Sum(快速幂,逆元)

    Codeforces 963 A. Alternating Sum 题目大意:给出一组长度为n+1且元素为1或者-1的数组S(0~n),数组每k个元素为一周期,保证n+1可以被k整除.给a和b,求对1 ...

  4. Codeforces 691E题解 DP+矩阵快速幂

    题面 传送门:http://codeforces.com/problemset/problem/691/E E. Xor-sequences time limit per test3 seconds ...

  5. 【codeforces 623E】dp+FFT+快速幂

    题目大意:用$[1,2^k-1]$之间的证书构造一个长度为$n$的序列$a_i$,令$b_i=a_1\ or\ a_2\ or\ ...\ or a_i$,问使得b序列严格递增的方案数,答案对$10^ ...

  6. Codeforces 691E Xor-sequences(矩阵快速幂)

    You are given n integers a1,  a2,  ...,  an. A sequence of integers x1,  x2,  ...,  xk is called a & ...

  7. codeforces 696C C. PLEASE(概率+快速幂)

    题目链接: C. PLEASE time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...

  8. Codeforces 954 dijsktra 离散化矩阵快速幂DP 前缀和二分check

    A B C D 给你一个联通图 给定S,T 要求你加一条边使得ST的最短距离不会减少 问你有多少种方法 因为N<=1000 所以N^2枚举边数 迪杰斯特拉两次 求出Sdis 和 Tdis 如果d ...

  9. [Luogu3242][HNOI2015]接水果

    Luogu 我今天做两道整体二分结果全都是BZOJ权限题??? sol 我们抓住"盘子的路径是水果的路径的子路径"这个条件. 考虑每一个盘子路径\((u,v)\),讨论它可以作为哪 ...

随机推荐

  1. GUID和UUID、CLSID、IID 区别及联系

    当初微软设计com规范的时候,有两种选择来保证用户的设计的com组件可以全球唯一: 第一种是采用和Internet地址一样的管理方式,成立一个管理机构,用户如果想开发一个COM组件的时候需要向该机构提 ...

  2. OpenCV学习笔记(1)

    一.读入图像 使用cv2.imread()读入图像,图像应该在此程序的工作路径,第二个参数是告诉函数应该如何读取这幅图片 cv2.IMREAD_COLOR:读入一副彩色图像.图像的透明度会被忽略,这是 ...

  3. jquery版本轮播图(es5版本,兼容高)

    优势:基于es5,兼容高.切换动画css配置,轻量,不包含多余代码,可扩展性很高,多个轮播图不会冲突,可配置独有namespace 注: 1.项目需要所写,所以只写了页码的切换,未写上一页下一页按钮, ...

  4. windows 开启/关闭本地连接的批处理程序

    ::命令前加@符号,表示不显示@后面的命令. @echo off title Open / Close Network ::本地网络适配器名称 set name=以太网 ::查看网络状态,后反向设定 ...

  5. 【Fiddler】开启手机的http或https抓包

    fiddler安装 下载fiddler最新版: 默认安装: 打开fiddler工具,默认界面: 选择上方,Tools-→options General界面 HTTPS界面 CONNECTIONS,po ...

  6. 浅谈 JVM 结构体系、类加载、JDK JRE JVM 三者的关系

    一.java类,创建.编译.到运行的工程: 1.随便建一个Java类,保存后就是一个.java文件, 2.然后我们使用 javac命令编译 .java文件,生产 .class文件. 3.再然后使用 j ...

  7. 初学node.js-nodejs中实现用户注册路由

    经过前面几次的学习,已经可以做下小功能,今天要实现的事用户注册路由. 一.users_model.js  功能:定义用户对象模型 var mongoose=require('mongoose'), S ...

  8. Python内置函数compile

    英文文档: compile(source, filename, mode, flags=0, dont_inherit=False, optimize=-1) Compile the source i ...

  9. (4.31)sql server中的xml数据操作

    关键词:xml数据转为行列方式显示 常规案例: declare @data xml declare @h int set @data=' <bookstore> <row> & ...

  10. java基础知识部分知识点

    1.Java常见的注释有哪些,语法是怎样的? 1)单行注释用//表示,编译器看到//会忽略该行//后的所文本  2)多行注释/* */表示,编译器看到/*时会搜索接下来的*/,忽略掉/* */之间的文 ...