最大的K-偏差排列

每次取可选范围里的最大的数字,如果最左侧的数字还没有使用就直接使用最左侧的数字

#pragma comment(linker, "/STACK:102400000,102400000")
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<vector>
#include<algorithm>
#include<iostream>
#include<map>
#include<queue>
#include<stack>
#include<string>
#include<functional>
#include<math.h>
//#include<bits/stdc++.h>
using namespace std;
typedef long long lint;
typedef vector<int> VI;
typedef pair<int, int> PII;
typedef queue<int> QI; void makedata() {
freopen("input.txt", "w", stdout);
fclose(stdout);
} int main() {
#ifndef ONLINE_JUDGE
freopen("input.txt", "r", stdin);
#endif
//makedata();
std::ios::sync_with_stdio(), cin.tie();
int n, k;
bool f[];
cin >> n >> k;
memset(f, false, sizeof(f));
for (int i = ; i <= n; i++) {
if (i - k > && !f[i - k]) {
f[i - k] = true;
cout << i - k << ' ';
continue;
}
for (int j = i + k; j > i - k; j--) {
if (j > n || j < ) continue;
if (!f[j]) {
f[j] = true;
cout << j << ' ';
break;
}
}
}
return ;
}

孤独的字符

枚举每个字符,计算它是一个孤独字符时包含它的区间有多少个

#pragma comment(linker, "/STACK:102400000,102400000")
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<vector>
#include<algorithm>
#include<iostream>
#include<map>
#include<queue>
#include<stack>
#include<string>
#include<functional>
#include<math.h>
//#include<bits/stdc++.h>
using namespace std;
typedef long long lint;
typedef vector<int> VI;
typedef pair<int, int> PII;
typedef queue<int> QI; void makedata() {
freopen("input.txt", "w", stdout);
fclose(stdout);
} string s;
int pre[], nex[], last[]; int main() {
#ifndef ONLINE_JUDGE
freopen("input.txt", "r", stdin);
#endif
//makedata();
std::ios::sync_with_stdio(), cin.tie();
cin >> s;
int n = s.length();
memset(last, -, sizeof(last));
for (int i = ; i < n; i++) {
pre[i] = last[s[i]];
nex[i] = n;
if (last[s[i]] >= ) nex[pre[i]] = i;
last[s[i]] = i;
}
lint ans = ;
for (int i = ; i < n; i++) {
ans += 1LL * (nex[i] - i) * (i - pre[i]);
}
cout << ans << endl;
return ;
}

秋天来了

这题有问题,都说了l是唯一最高完了样例好几个最高???最高的还能看到别人???

Nim森林

这题跟这棵树没啥关系。两个回合以后,是一个典型的反nim游戏,先手获胜的条件为:1)所有堆的石子个数为1,且NIM_sum=0或2)至少有一堆的石子个数大于1,且 NIM_sum≠0。第一种获胜情况是所有堆狮子个数为1且有偶数堆,这种情况是不可能达到的。经过第一回合操作后,只要有石子数为1的石堆,B都可以拿完多于1的石堆且剩下奇数个石子数为1的石堆,所以只需考虑第二种情况(且所有石堆石子数大于1)。按代价从大到小的顺序添加各个石堆的石子数到线性基中,成功添加进去的就是第二回合给B留下的。

#include <bits/stdc++.h>
using namespace std;
using LL = int64_t;
using LD = long double;
const LL INF = 0x3f3f3f3f;
const LL mod = 1e9 + ; template <typename T>
struct LnBase{
int sz, szc;
T *x;
int *y;
LnBase (){x = ; sz = sizeof(T) << ; szc = -; resize(sz);}
void resize(int size){
sz = size; if(!x) delete(x); x = new T[sz + ]; y = new int[sz + ];
memset(x, , sz * sizeof(T)); memset(y, , sz << );
}
T operator[](int h){return x[h];}
int add(T v){
for(int i = sz - ; i >= ; i--)
if(v & (T) << i){if(!x[i]){x[i] = v; szc = -; return i;} v ^= x[i];}
return -;
}
int find(T v){
for(int i = sz - ; i >= ; i--){
if(v & (T) << i && x[i]) v ^= x[i]; if(!v) return ;}
return ;
}
T Max(){
T s = ;
for(int i = sz - ; i >= ; i--){if((s ^ x[i]) > s) s ^= x[i];}
return s;
}
T Min(){
for(int i = ; i < sz; i++) if(x[i]) return x[i];
return -;
}
void Canonicity(){
int i, j;
for(i = sz - ; i > ; i--)
for(j = i - ; j >= ; j--) if(x[i] & (T) << j) x[i] ^= x[j];
for(szc = i = ; i < sz; i++) if(x[i]) y[szc++] = i;
}
T Kth(long long K){
if(szc < ) Canonicity(); if(K >= 1ll << szc) return -; T s = ;
for(int i = szc - ; i >= ; i--) if(K & 1ll << i) s ^= x[y[i]];
return s;
}
}; struct node {
__int128 a, t;
bool operator<(const node &e) const { return t > e.t; }
};
int main() {
ios::sync_with_stdio();
cin.tie();
int n;
cin >> n;
n--;
vector<node> a(n);
for (auto &i : a) {
LL u, v, a, t;
cin >> u >> v >> a >> t;
i.a = a;
i.t = u ^ v ^ t;
}
sort(a.begin(), a.end());
int flag = ;
__int128 ans = , sum = ;
LnBase<__int128> b;
for (auto& s : a) {
sum += s.t;
if (s.a == ) continue;
flag = ;
if (b.add(s.a) != -) ans += s.t;
}
if (flag) cout << "No\n";
else {
ans = sum - ans;
string s = "";
while (ans) {
s += '' + ans % ;
ans /= ;
}
if (s == "") s = "";
reverse(s.begin(), s.end());
cout << s << '\n';
}
}

[hihocoder][Offer收割]编程练习赛58的更多相关文章

  1. hihocoder [Offer收割]编程练习赛4

    描述 最近天气炎热,小Ho天天宅在家里叫外卖.他常吃的一家餐馆一共有N道菜品,价格分别是A1, A2, ... AN元.并且如果消费总计满X元,还能享受优惠.小Ho是一个不薅羊毛不舒服斯基的人,他希望 ...

  2. hihocoder [Offer收割]编程练习赛61

    [Offer收割]编程练习赛61 A:最小排列 给定一个长度为m的序列b[1..m],再给定一个n,求一个字典序最小的1~n的排列A,使得b是A的子序列. 贪心即可,b是A的子序列,把不在b中的元素, ...

  3. ACM学习历程—Hihocoder [Offer收割]编程练习赛1

    比赛链接:http://hihocoder.com/contest/hihointerview3/problem/1 大概有一个月没怎么打算法了.这一场的前一场BC,也打的不是很好.本来Div1的A和 ...

  4. hihocoder offer收割编程练习赛8 C 数组分拆

    思路:(引自bfsoyc的回答:http://hihocoder.com/discuss/question/4160) 动态规划.状态dp[i]表示 前i个数的合法的方案数,转移是 dp[i] = s ...

  5. hihocoder [Offer收割]编程练习赛18 C 最美和弦(dp)

    题目链接:http://hihocoder.com/problemset/problem/1532 题解:一道基础的dp,设dp[i][j][k][l]表示处理到第几个数,当前是哪个和弦错了几次初始x ...

  6. hihoCoder [Offer收割]编程练习赛3 D子矩阵求和

    子矩阵求和 http://hihocoder.com/discuss/question/3005 声明一下: n是和x一起的,m是和y一起的 x是横着的,y是纵着的,x往右为正,y往下为正 (非常反常 ...

  7. hihocoder [Offer收割]编程练习赛52 D 部门聚会

    看了题目的讨论才会做的 首先一点,算每条边(u, v)对于n*(n+1)/2种[l, r]组合的贡献 正着算不如反着算 哪些[l, r]的组合没有包含这条边(u, v)呢 这个很好算 只需要统计u这半 ...

  8. hihocoder [Offer收割]编程练习赛14

    A.小Hi和小Ho的礼物 谜之第1题,明明是第1题AC率比C还要低.题目是求在n个不同重量袋子选4袋,2袋给A,2袋给B,使2人获得重量相同,求问方案数. 我也是一脸懵b...o(n2)暴力枚举发现把 ...

  9. hihocoder [Offer收割]编程练习赛8

    第一次做这种比赛,被自己坑的好惨... A.这道题的关键其实是如果有k和n满足kD+F>nL>kD则不能走无限远,分支看似难整理,其实比较简单,F>L根本就不用算了,明摆着就是Bsi ...

随机推荐

  1. hdu 5017 模拟退火算法

    hdu 5017 http://blog.csdn.net/mypsq/article/details/39340601 #include <cstdio> #include <cs ...

  2. Non-inclusive cache method using pipelined snoop bus

    A non-inclusive cache system includes an external cache and a plurality of on-chip caches each havin ...

  3. 高数(A)下 第十章

    10.1 10.2 10.3 10.4 10.5 10.7 自测题

  4. [bzoj1821][JSOI2010]部落划分(贪心)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1821 分析:题目看起来很吊,但只要贪心就行了,每次取相邻最近的两个点所在的集合合并知道 ...

  5. Eureka集群的那些坑

    今天遇到一个Eureka集群的一个坑. 问题现场类似是这样的:两台Eureka组成的服务注册中心集群,两台服务提供方server1.server2,两个服务调用方client1.client2. 正常 ...

  6. 启动第二个Activity

    启动第二个Activity activity_main.xml文件: <? xml version="1.0" encoding="utf-8"?> ...

  7. torch lua tips

    1.luarocks 离线安装Moses 下载 Moses-Moses-1.6.1-1.zip cd Moses-Moses-1.6.1-1 Moses-Moses-1.6.1-1# luarocks ...

  8. Robot Framework 使用技巧 快捷键

        ctrl+alt+space 自动带出相关关键字,以及相关用法,里边有对应参数的说明. Ctrl+鼠标悬浮 直接显示关键字的相关用法 F5 关键字说明 (方法名函数名)             ...

  9. 全面解析布局(Grid & Canvas &StackPanel &Wrappanel) 转

    写这篇文章前,特意在百度搜索了一下,发现目前网上介绍布局的文章不多,质量也不是很高.拿grid和canvas来讲,这两个布局容器还是有许多小细节值得讲的,如果你不了解的话,开发中经常会遇到一些让人匪夷 ...

  10. 二分查找法(binary search)

    二分查找法:一种在有序列表中查找某个值的算法,它每次都将待查找的空间分为两半,在其中一般继续查找. 使用二分查找的前提是:已经排序好的列表.否则,sum对其查找的结果不做保证. 代码实现: // 使用 ...