8.26 T2 日记和欧拉函数(欧拉函数)

2024-08-27 00:12
文章标签 函数 欧拉 t2 日记 8.26

本文主要是介绍8.26 T2 日记和欧拉函数(欧拉函数),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://cplusoj.com/d/senior/p/NOD2301B

发现 x ≤ B x\le B xB 时答案是 x x x

x > B + 500 x>B+500 x>B+500 左右答案是1

我们预处理中间的就行

预处理直接暴力做,求 max ⁡ ϕ \max \phi maxϕ 的话相当于求小于它的质数

#include<bits/stdc++.h>
using namespace std;
#ifdef LOCAL#define debug(...) fprintf(stdout, ##__VA_ARGS__)#define debag(...) fprintf(stderr, ##__VA_ARGS__)
#else#define debug(...) void(0)#define debag(...) void(0)
#endif
#define int long long
inline int read(){int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;
ch=getchar();}while(ch>='0'&&ch<='9'){x=(x<<1)+
(x<<3)+(ch^48);ch=getchar();}return x*f;}
#define Z(x) (x)*(x)
#define pb push_back
#define fi first
#define se second
//#define M
//#define mo
#define N 510
int n, m, i, j, k, T, B;
int mx, phi[N], f[N], sm[N], l, r;
int ans;  
map<int, int>mp; int qry(int x) {if(mp[x]) return mp[x]; int ans = 1, i, j; 
//	debug("phi[%lld] = ", x); for(i = 2; i * i <= x; ++i) if(x % i == 0) {j = 1; while(x % i == 0) x /= i, j *= i; j /= i; j *= (i - 1); ans *= j; }if(x > 1) ans *= (x - 1); 
//	debug("%lld\n", ans); return mp[x] = ans; 
}signed main()
{#ifdef LOCALfreopen("in.txt", "r", stdin);freopen("out.txt", "w", stdout);#endif
//	srand(time(NULL));
//	T=read();
//	while(T--) {
//
//	}T = read(); B = read(); for(j = 1 + B; ; --j) if(j == 1 || qry(j) == j - 1) break; 
//	debug("Out\n"); for(i = 1; i <= 400; ++i) {k = i + B; phi[i] = qry(k); if(phi[i] == k - 1) j = k; mx = j - 1 - B; f[i] = k; if(i <= 6) debug("[%lld]%lld %lld | %lld\n", k, mx, phi[i], j); if(mx <= 0) continue; while(mx-- && f[i] != 1) f[i] = qry(f[i]); if(i <= 6) debug("[%lld] %lld\n", k, f[i]); }for(i = 1; i <= 400; ++i) sm[i] = sm[i - 1] + f[i]; while(T--) {l = read(); r = read(); ans = 0; if(r <= B) { printf("%lld\n", (l + r) * (r - l + 1) / 2); continue; }if(l <= B) ans += (l + B) * (B - l + 1) / 2, l = B + 1; if(l >= B + 400) { printf("%lld\n", r - l + 1); continue; }if(r >= B + 400) ans += (r - (B + 400) + 1), r = B + 400 - 1; debug("[%lld %lld] %lld\n", l, r, ans); l -= B; r -= B; ans += sm[r] - sm[l - 1]; debug("[%lld %lld]\n", l, r); printf("%lld\n", ans); }return 0;
}

这篇关于8.26 T2 日记和欧拉函数(欧拉函数)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1110087

相关文章

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

uva 1342 欧拉定理(计算几何模板)

题意: 给几个点,把这几个点用直线连起来,求这些直线把平面分成了几个。 解析: 欧拉定理: 顶点数 + 面数 - 边数= 2。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#inc

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

Unity3D 运动之Move函数和translate

CharacterController.Move 移动 function Move (motion : Vector3) : CollisionFlags Description描述 A more complex move function taking absolute movement deltas. 一个更加复杂的运动函数,每次都绝对运动。 Attempts to

✨机器学习笔记(二)—— 线性回归、代价函数、梯度下降

1️⃣线性回归(linear regression) f w , b ( x ) = w x + b f_{w,b}(x) = wx + b fw,b​(x)=wx+b 🎈A linear regression model predicting house prices: 如图是机器学习通过监督学习运用线性回归模型来预测房价的例子,当房屋大小为1250 f e e t 2 feet^