AOE还是单体?
data:image/s3,"s3://crabby-images/f0db0/f0db02e98880d7168c7804697fd882b3e9ed3509" alt=""
data:image/s3,"s3://crabby-images/2244f/2244fa47a3de34efebdad0f6baa391985299e6b4" alt=""
#include <cstdio>
#include <algorithm>
#include <iostream>
#include <cstring>
#include <string>
using namespace std;
const int N = 2e5 + 10;
typedef long long ll;
ll n,x;
ll a[N],mx;
int main(){
scanf("%lld%lld",&n,&x);
for(int i = 1;i <= n;i++){
scanf("%lld",a+i);
}
sort(a,a+n);
ll k = n - x;
if(k <= 0) k = 0;
else k = a[k];
ll ans = k*x;
for(int i = 1;i <= n;i++){
a[i] -= k;
if(a[i] > 0) ans += a[i];
}
printf("%lld\n",ans);
return 0;
}
k-size字符串
data:image/s3,"s3://crabby-images/2c653/2c6538aced6e6645d31a5c6a672df658fde0e50b" alt=""
data:image/s3,"s3://crabby-images/7f25f/7f25f9e5117e34a5850e8634d1f65dde9787f597" alt=""
data:image/s3,"s3://crabby-images/caed0/caed0edda2369fbcb460a81a478018d927b55273" alt=""
data:image/s3,"s3://crabby-images/bb4f0/bb4f0e0ecf5be17c07592452d1a49c4ba74dd8ed" alt=""
data:image/s3,"s3://crabby-images/f96b9/f96b91147a454483f59408361b9a4e5563694e18" alt=""
data:image/s3,"s3://crabby-images/81613/81613e3c8c24c713caac3698ae212ae7d16353e7" alt=""
data:image/s3,"s3://crabby-images/9e818/9e8182e9999fa782d47ea6944aabf28cd4905adc" alt=""
data:image/s3,"s3://crabby-images/cada6/cada6b2371cdd24db36ba5b78f550790291765ae" alt=""
data:image/s3,"s3://crabby-images/d8f5e/d8f5e4bedbd00c24a45a4a0c7439513190189a55" alt=""
data:image/s3,"s3://crabby-images/21db8/21db8f84be2d41016179622267f2cb46c6b0cb92" alt=""%20*%20C(m%20-%201%2Ccnt2%20-%201)&preview=true)
data:image/s3,"s3://crabby-images/dc452/dc452b87e2741c6bb5d9cfafb26d96aed40af756" alt=""
data:image/s3,"s3://crabby-images/bcdfc/bcdfcc4ddc3f61f19eba6b7d090250a942cb9af3" alt=""%20*%20C(m%20-%201%2Ccnt1%20-%201)&preview=true)
data:image/s3,"s3://crabby-images/df2c7/df2c7dabbd6184f0c15146dd2aaeb6f9c23ec65d" alt=""
data:image/s3,"s3://crabby-images/ef8dd/ef8dd1bc9e7309f307a17abf36b1ee4d3cea0067" alt=""%E6%98%AF%E5%B0%86n%E5%88%86%E6%88%90cnt1%E4%B8%AA%E8%BF%9E%E9%80%9A%E5%9D%97%E7%9A%84%E6%96%B9%E6%A1%88%EF%BC%8C%E7%9B%B8%E5%BD%93%E4%BA%8E%E6%9C%89n%E4%B8%AA1%EF%BC%8Cn-1%E4%B8%AA%E9%97%B4%E9%9A%94&preview=true)
data:image/s3,"s3://crabby-images/26475/26475926a1fb89686635c4b307309dd8f28e54ac" alt=""
data:image/s3,"s3://crabby-images/350a2/350a2ebf0d125e64e1e983418e89c39eed1bc5ed" alt=""%E6%98%AF%E5%B0%86m%E5%88%86%E6%88%90cnt2%E4%B8%AA%E8%BF%9E%E9%80%9A%E5%9D%97%E7%9A%84%E6%96%B9%E6%B3%95&preview=true)
data:image/s3,"s3://crabby-images/bc35f/bc35f1739678026c9f2c811cbf3671a2795b55a9" alt=""
data:image/s3,"s3://crabby-images/0fd7d/0fd7d0c82e14197c8a7edec19f02fd7d2d8f57bc" alt=""%20*%20C(m%20-%201%2Ccnt2%20-%201)&preview=true)
#include <cstdio>
#include <iostream>
using namespace std;
typedef long long ll;
const ll mod = 1e9 + 7;
const int N = 1e5;
ll fac[N + 10],facInv[N + 10];
ll qpow(ll a,ll b){
ll res = 1;
while(b){
if(b&1) res = res * a % mod;
a = a * a % mod;
b >>= 1;
}
return res;
}
ll inv(ll x){
return qpow(x,mod-2);
}
void init(){
fac[0] = 1;
for(int i = 1;i <= N;i++){
fac[i] = fac[i - 1] * i % mod;
}
facInv[N] = inv(fac[N]);
for(int i = N - 1;i >= 0;i--){
facInv[i] = facInv[i+1] * (i+1) % mod;
}
}
ll C(int n,int m){
if(m < 0 || m > n) return 0;
return (fac[n] * facInv[m] % mod ) * facInv[n-m] % mod;
}
int n,m,k;
int main(){
init();
scanf("%d%d%d",&n,&m,&k);
int cnt1 = k/2,cnt2 = k - k/2;
ll ans = C(n - 1,cnt1 - 1) * C(m - 1,cnt2 - 1) % mod;
swap(n,m);
ans = (ans + C(n - 1,cnt1 - 1)*C(m - 1,cnt2 - 1) % mod) % mod;
printf("%lld\n",ans);
return 0;
}
白魔法师
data:image/s3,"s3://crabby-images/a3a97/a3a979571ce6e7e489c70edaa4080bdd78be0fd7" alt=""
data:image/s3,"s3://crabby-images/1ba33/1ba336df25d8789f7fa5e7542583c092a9899937" alt=""
data:image/s3,"s3://crabby-images/41b87/41b87d2d067d110fa63edb08b589eaade30d4265" alt=""
data:image/s3,"s3://crabby-images/4a21e/4a21e9518d2583ff30c29799acfe9fc4eca54522" alt=""
#include <cstdio>
#include <vector>
using namespace std;
const int N = 1e5 + 10;
vector<int> G[N];
int n,fa[N],sz[N];
char s[N];
int find(int x){
return fa[x] == x?x:fa[x] = find(fa[x]);
}
void merge(int x,int y){
int fx = find(x),fy = find(y);
if(fx != fy){
fa[fy] = fx;
sz[fx] += sz[fy];
}
}
int main(){
scanf("%d%s",&n,s + 1);
for(int i = 1;i <= n;i++) fa[i] = i,sz[i] = 1;
for(int i = 1,u,v;i < n;i++){
scanf("%d%d",&u,&v);
G[u].push_back(v);
G[v].push_back(u);
if(s[u] == s[v] && s[u] == 'W') merge(u,v);
}
int mx = 0;
for(int u = 1;u <= n;u++){
int res = 1;
if(s[u] == 'W') res = sz[find(u)];
else{
for(int i = 0;i < G[u].size();i++){
int v = G[u][i];
if(s[v] == 'W') res += sz[find(v)];
}
}
mx = max(res,mx);
}
printf("%d\n",mx);
return 0;
}
抽卡
data:image/s3,"s3://crabby-images/6406b/6406b0fd1105009174ab9f1d9c469efd27462e87" alt=""
data:image/s3,"s3://crabby-images/c50a4/c50a4b7bd9b3b6113dc0c5660a8b6e9d038cd3e6" alt=""%20%5C%25%20mod&preview=true)
data:image/s3,"s3://crabby-images/06c65/06c65ca6a3986968ff96846dcc36478ec745ab8b" alt=""
data:image/s3,"s3://crabby-images/20832/2083249b65ee9e0c36f7f420dc896f54a2973ccb" alt=""
data:image/s3,"s3://crabby-images/144ab/144abc083ec97824b9122c6f1dd5fb59d0a5b289" alt=""%20*%20inv(a_i)&preview=true)
#include <cstdio>
using namespace std;
typedef long long ll;
const int N = 1e5+10;
const ll mod = 1e9 + 7;
ll qpow(ll a,ll b){
ll res = 1;
while(b){
if(b&1) res = res*a %mod;
a = a*a % mod;
b >>= 1;
}
return res%mod;
}
ll inv(ll x){
return qpow(x,mod-2);
}
ll a[N],b[N];
int n;
int main(){
scanf("%d",&n);
for(int i = 1;i <= n;i++) scanf("%lld",a+i);
for(int i = 1;i <= n;i++) scanf("%lld",b+i);
ll res = 1;
for(int i = 1;i <= n;i++){
res = (res * (a[i]-b[i]) % mod) * inv(a[i]) % mod;
}
res = (1 - res + mod) % mod;
printf("%lld\n",res);
return 0;
}
点击消除
data:image/s3,"s3://crabby-images/51484/51484ec583aa9f1aa6b47ebbdb7920aff5284170" alt=""
data:image/s3,"s3://crabby-images/0aad4/0aad4968df5be4ec928ca15b6089b7644c1bfd04" alt=""
#include <cstdio>
#include <stack>
#include <iostream>
#include <cstring>
using namespace std;
const int N = 3e5+10;
char str[N];
struct stack{
char a[N];
int l = 0;
void push(char x){
a[++l] = x;
}
char top(){
return a[l];
}
void pop(){
l--;
}
bool empty(){
if(l > 0) return 0;
return 1;
}
}s;
int main(){
scanf("%s",str);
s.push(str[0]);
for(int i = 1;i < strlen(str);){
if(s.empty()){
s.push(str[i]);
i++;
}else if(str[i]!=s.top()){
s.push(str[i]);
i++;
}else{
char ch = s.top();
int be = i - 1,en;
do{
i++;
}while(i<strlen(str)&&str[i]==s.top());
en = i - 1;
i = en + 1;
if(( (en - be + 1)%2==0 )&&!s.empty()) s.pop();
}
}
if(s.empty()) puts("0");
else{
char ans[N];
int idx = 0;
while(!s.empty()){
ans[++idx] = s.top();
s.pop();
}
for(int i = idx;i > 0;i--){
printf("%c",ans[i]);
}
puts("");
}
return 0;
}
疯狂的自我检索者
data:image/s3,"s3://crabby-images/49480/49480444861a93cd73350d43412b988449e133e6" alt=""
#include <cstdio>
#include <iostream>
using namespace std;
const int N = 2e5 + 10;
double sum;
int n,m;
int main(){
scanf("%d%d",&n,&m);
for(int i = 1;i <= n-m;i++){
double x;scanf("%lf",&x);
sum += x;
}
double mx = sum + m*5,mi = sum + m*1;
mx = mx / (1.0*n),mi = mi / (1.0*n);
printf("%.5f %.5f\n",mi,mx);
return 0;
}
解方程
data:image/s3,"s3://crabby-images/c4930/c4930e9f325b98c87314f6e52e6ee856787e9a10" alt=""%20%3D%20x%5Ea%20%2B%20b*lnx%20%E6%98%AF%E4%B8%AA%E5%8D%95%E8%B0%83%E9%80%92%E5%A2%9E%E5%87%BD%E6%95%B0%EF%BC%8C%E4%BA%8C%E5%88%86%E6%9F%A5%E6%89%BE%EF%BC%8C%E5%9C%A8%E6%9F%A5%E6%89%BE%E8%BF%87%E7%A8%8B%E4%B8%AD%E5%A6%82%E6%9E%9Cfabs(cal(mid)%20-%20c)%E5%B0%8F%E4%BA%8E1e-7%E7%9B%B4%E6%8E%A5break%E6%8E%89&preview=true)
#include <cstdio>
#include <cmath>
#include <iostream>
using namespace std;
int a,b,c;
const double eps = 1e-7;
double cal(double x){
double res = pow(x,a) + b*log(x);
return res;
}
int main(){
scanf("%d%d%d",&a,&b,&c);
double l = 0,r = 1e9;
double ans = -1;
while(r - l > eps){
double mid = (l + r)/2;
if(fabs(cal(mid) - c) < eps){
ans = mid;
break;
}else if(cal(mid) >= c){
ans = mid;
r = mid;
}else l = mid;
}
printf("%.14f\n",ans);
}
神奇的字母(二)
data:image/s3,"s3://crabby-images/64c1d/64c1dad0b2f4b45bc6f0bc8b1e45344256b7152f" alt=""
#include <cstdio>
#include <iostream>
#include <string>
using namespace std;
string str;
int num[30];
int main(){
while(cin>>str){
for(int i = 0;i < str.size();i++){
num[str[i] - 'a']++;
}
}
int mx = 0,mx_ch = -1;
for(int i = 0;i < 26;i++){
if(num[i] > mx){
mx = num[i];
mx_ch = i;
}
}
printf("%c\n",(char)('a' + mx_ch));
return 0;
}
十字爆破
data:image/s3,"s3://crabby-images/57cbd/57cbd43d593365e796195f6ae1f186617a77c006" alt=""
data:image/s3,"s3://crabby-images/252d0/252d0413400a6eb8c52d18f8d4886315aeb3dfce" alt=""%E5%B0%B1%E6%98%AF%20col%5Bi%5D%20%2B%20row%5Bj%5D%20-%20val%5Bi%5D%5Bj%5D&preview=true)
data:image/s3,"s3://crabby-images/ad092/ad092ad672968c1c711bad01809c28b970802a07" alt=""
#include <cstdio>
#include <algorithm>
#include <iostream>
using namespace std;
typedef long long ll;
const int N = 1e6 + 10;
ll row[N],col[N];
int n,m;
ll a[N];
int num(int i,int j){
return (i-1)*m + j;
}
int main(){
scanf("%d%d",&n,&m);
for(int i = 1;i <= n;i++){
for(int j = 1;j <= m;j++){
scanf("%lld",&a[num(i,j)]);
col[i] = col[i] + a[num(i,j)];
row[j] = row[j] + a[num(i,j)];
}
}
for(int i = 1;i <= n;i++){
for(int j = 1;j <= m;j++){
printf("%lld ",col[i]+row[j]-a[num(i,j)]);
}
puts("");
}
return 0;
}
异或和之和
data:image/s3,"s3://crabby-images/858fa/858fafc4d7c24b3ea3ac625d62c89cf930b02b18" alt=""
data:image/s3,"s3://crabby-images/72898/728982a7c6684761cb8725bff49218da9e9ab41c" alt=""
data:image/s3,"s3://crabby-images/da043/da04333ba737fc893d3870c2b129eed2c43e34dd" alt=""%20*%20(C(a_i%2C3)%20%2B%20a_i*C(b_i%2C2))&preview=true)
#include <cstdio>
using namespace std;
typedef long long ll;
const ll mod = 1e9 + 7;
const int N = 2e5 + 10;
int a[N];
int num[64][2];
ll quick_mod(ll a, ll b){
ll ans=1;
a%=mod;
while(b){
if(b&1){
ans=ans*a%mod;
b--;
}
b>>=1;
a=a*a%mod;
}
return ans;
}
ll C(ll n,ll m){
if(m>n) return 0;
ll ans=1;
for(int i=1;i<=m;i++){
ll a=(n+i-m)%mod;
ll b=i%mod;
ans=ans*(a*quick_mod(b,mod-2)%mod)%mod;
}
return ans;
}
int main(){
int n;scanf("%d",&n);
for(int i = 0;i < n;i++){
ll x;scanf("%lld",&x);
for(int j = 0;j < 64;j++){
ll k = x % 2;
num[j][k]++;
x >>= 1ll;
}
}
ll ans = 0;
for(ll i = 0;i < 64;i++){
ans = (ans + ((1ll<<i) % mod) * (C(num[i][1],3) + C(num[i][0],2)*C(num[i][1],1) % mod) % mod) % mod;
}
printf("%lld\n",ans);
return 0;
}