首页 > 编程语言 >第 45 届国际大学生程序设计竞赛(ICPC)亚洲区域赛(昆明)

第 45 届国际大学生程序设计竞赛(ICPC)亚洲区域赛(昆明)

时间:2022-10-26 18:22:20浏览次数:390  
标签:allh int 45 tr long ICPC 程序设计 include root

H Hard Calculation

签到题

J Parallel Sort

分析:很好想到找环 对于每个环 最多两次操作即可还原

构造每个环的方案 :每次将环脱去一对即可

开始我构造的按照顺序脱去一对 但是只过了70个点 正解为首尾依次脱环

#include<iostream>
#include<vector>
using namespace std;
typedef long long ll;

struct huan
{
    vector<int> sig;//环中数据的位置
    int type;//环的型号,一元环为0,2元为1,更多为2
};

int maxtip = 0;//最大环型号
huan allh[100005];//环组
int aback = 0;//环组尾标
int orig[100005];//原始数据
int seat[100005];//i在原始数据中的位置
bool used[100005];//开环时被使用标记

int main()
{
    int n; cin >> n;
    for (int i = 1; i <= n; i++)
    {
        cin >> orig[i];
        seat[orig[i]] = i;
    }

    //打出所有环
    for (int i = 1; i <= n; i++)
    {
        if (used[i] == 1)
            continue;//已经入环的去掉
        int t = aback;
        aback++;//栈顶移动
        allh[t].sig.push_back(i);//环的开头
        used[i] = 1;
        int j = orig[i];
        while (1)
        {
            if (j != i)//不是环尾
            {
                allh[t].sig.push_back(j);
                used[j] = 1;
                j = orig[j];
            }
            else//是环尾
            {
                used[j] = 1;
                break;//不进入,直接跳出
            }
        }

        //给出类型
        int size = allh[t].sig.size();
        if (size == 1)
            allh[t].type = 0;
        else if(size == 2)
            allh[t].type = 1;
        else
            allh[t].type = 2;
        maxtip = max(maxtip, allh[t].type);
    }

    //输出结果
    cout << maxtip << endl;
    for (int i = maxtip; i > 0; i--)//每一行
    {
        vector<int> y;//装输出数据的数组
        for (int j = 0; j < aback; j++)//遍历每个环
        {
            if (allh[j].type >= i)//只有等级足够的环才来
            {
                int right = allh[j].sig.size() - 1;
                int left = i == 2 || allh[j].type == 1 ? 0 : 1;
                while (left < right)
                {
                    y.push_back(allh[j].sig[left]);
                    y.push_back(allh[j].sig[right]);
                    left++;
                    right--;
                }
            }
        }
        cout << y.size() / 2;
        for (int k = 0; k < y.size(); k++)
        {
            cout << " " << y[k];
        }
        cout << endl;
    }
}


L Simone and graph coloring

分析:考虑如果完全降序 整个图即为一个完全图 这样每个点的颜色都需要不同

所以想到对于每个下降子序列的长度就是所需颜色的数量 最长就是答案

至于方案数在求最长下降子序列的过程中跟新

需要用到二分dp来求解

#include<bits/stdc++.h>
using namespace std;
const int N=1e6+10;
int T,n,a[N],b[N],ls[N];

int get(int l,int r,int x){
	while(l<r){
		int mid=(l+r)>>1;
		if(ls[mid]>x) l=mid+1;
		else r=mid;
	}
	return l;
}

void solve(){
	int tot=0; cin>>n;
	for(int i=1;i<=n;i++) cin>>a[i];
	for(int i=1;i<=n;i++){
		if(tot==0||a[i]<ls[tot]) ls[b[i]=++tot]=a[i];
		else{
			int tmp = get(1,tot,a[i]);
			b[i] = tmp;
			ls[tmp] = a[i];
		}
	}
	cout<<tot<<"\n";
	for(int i=1;i<=n;i++) cout<<b[i]<<" \n"[i==n];
}

int main(){
	cin>>T;
	while(T--) solve();
}

M Stone Games

题意:求静态区间数的选取集合不能构造出的和的最小值,在线

分析:
如果没有1,则凑不出来的最小数为1
否则设有x个1
显然,一定可以凑出[1,x]
注意到如果剩余大于1的数中最小数为k,若k<=x+1
则可以凑出[1,x+k]

推知若当前可以凑出[1,x],剩余数中所有小于等于x+1的数,均可累加到连续上限中
即凑出[1,x+Σsi(si<=x+1)]
若找不到新增的数,则答案为x+1。

主席树维护区间小于等于某个数的和,可以不初始化直接边插入边建树

#include <iostream>
#include <cstring>
#include <algorithm>
#define int long long

using namespace std;
const int N = 1e6+10,inf = 1e9;

int n,m,idx,root[N];

struct Node{
    int l,r;
    int sum;
}tr[N*50];

int insert(int p,int l,int r,int x){
    int q=++idx;
    tr[q]=tr[p];
    if(l==r){
        tr[q].sum+=x;
        return q;
    }
    int mid=l+r>>1;
    if(x<=mid) tr[q].l=insert(tr[p].l,l,mid,x);
    else tr[q].r=insert(tr[p].r,mid+1,r,x);
    tr[q].sum=tr[tr[q].l].sum+tr[tr[q].r].sum;
    return q;
}

int query(int q,int p,int l,int r,int ql,int qr){
    if(l>=ql&&r<=qr) return tr[q].sum-tr[p].sum;
    if(l>qr||r<ql) return 0;
    int mid=l+r>>1;
    return query(tr[q].l,tr[p].l,l,mid,ql,qr)+query(tr[q].r,tr[p].r,mid+1,r,ql,qr);
}

signed main(){
    cin>>n>>m;

    for(int i=1,t;i<=n;i++){
        cin>>t;
        root[i]=insert(root[i-1],0,inf,t);
    }

    int res=0;

    while(m--){
        int l,r;
        cin>>l>>r;
        l=(res+l)%n+1,r=(res+r)%n+1;
        if(l>r) swap(l,r);
        int x=query(root[r],root[l-1],0,inf,1,1);
        int last=x;
        while(1){
            int sum=query(root[r],root[l-1],0,inf,1,min(inf,x+1))-last;
            if(!sum) break;
            x+=sum,last=x;
        }
        res=x+1;
        cout<<res<<endl;
    }

    return 0;
}

J Mr. Main and Windmills

分析:就是暴力就好 计算几何不在我的范围类

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
typedef long long LL;
LL x1,y1,x2,y2;
LL  n,m;
struct node
{
	LL x;
	LL y;
}N[1001];
vector<double> V[1001];
int main()
{
	cin>>n>>m;
	cin>>x1>>y1>>x2>>y2;
	for(int a=1;a<=n;a++) cin>>N[a].x>>N[a].y;
	for(int i=1;i<=n;i++)
	 for(int j=1;j<=n;j++)
	 if(i!=j)
	 {
	 	LL x3=N[i].x,y3=N[i].y,x4=N[j].x,y4=N[j].y;
	 	double t1=(double)(x3 * (y4 - y3) + y1 * (x4 - x3) - y3 * (x4 - x3) - x1 * (y4 - y3)) / ((x2 - x1) * (y4 - y3) - (x4 - x3) * (y2 - y1));
	 	if(t1>0&&t1<1) V[i].push_back(t1);
	 }
	 for(int a=1;a<=n;a++) sort(V[a].begin(),V[a].end());
	while(m--)
	{
		int h,k;
		cin>>h>>k;
		if(k<=V[h].size()) printf("%.6f %.6f\n",x1+V[h][k-1]*(x2-x1),y1+V[h][k-1]*(y2-y1));
		else cout<<-1<<"\n";
	}	
}

标签:allh,int,45,tr,long,ICPC,程序设计,include,root
From: https://www.cnblogs.com/wzxbeliever/p/16829519.html

相关文章

  • 2020icpc沈阳H
    优化转移DPProblem-H-Codeforces题意Aloha要骑单车,可以单独花费\(r\)元骑1次,也可以购买某一种单车卡,第\(i\)种单车卡\(c_i\)元,若在第\(t\)天购买,可以在......
  • 洛谷 P6453
    设第\(i\)列高\(h_i\),建立序列\(h_i\)的小根笛卡尔树,然后树形DP。发现这样就将原来不规整的图形剖分成若干个矩形:我们发现,这样构成的若干个矩形正好对应小根笛卡......
  • JavaScript高级程序设计笔记12 BOM
    BOMBOM的核心——window对象窗口和弹窗location对象——页面信息navigator对象——浏览器信息history对象——浏览器历史记录BOM是使用JavaScript开发Web应用程序的......
  • C程序设计(谭浩强)学习笔记——杂叙
    第一章1.程序:一组计算机能识别和执行的指令;2.机器语言(1,0组成);汇编语言(低级语言);高级语言(面向过程、面向对象);第二章1.程序主要包括两方面的信息:数据结构(对数据的描述)、算法(对......
  • 2022 年上海市大学生程序设计竞赛 - 十月赛 B. Questions on Binary Tree
    给定一棵n个节点的完全二叉树以及m次询问,每次询问需要计算给定节点在先序遍历的顺序。思路就是从给定的节点不断向上跳,如果当前节点是左儿子则给答案+1,是右儿子则给答案+1......
  • CF1458C Latin Square
    对于一个排列\(p_i\),将其表示为\((i,p_i)\),那么它的逆排列可表示为\((p_i,i)\)这道题\(i,j,a_{i,j}\)均为排列,考虑用三元组\((i,j,a_{i,j})\)表示。(为了方便下......
  • 面向对象程序设计
    1.    2.    3.    4.    5.    6.   7.     8.    9.   ......
  • PAT 乙级 1045 快速排序 (25分)
    1045快速排序(25分)著名的快速排序算法里有一个经典的划分过程:我们通常采用某种方法取一个元素作为主元,通过交换,把比主元小的元素放到它的左边,比主元大的元素放到它的右边......
  • 2022计算机基础与程序设计
    目录作业要求作业提交地址作业提交情况情况较上周有退步,上周未提交7人,这周未提交10人作业内容要求学习目标总结要求作业情况优点缺点优秀作业助教小结作业要求作业提交地......
  • Delphi 经典游戏程序设计40例 的学习 例35半自动制作迷宫的扩展,3种变化
    unitR35;interfaceusesWindows,Messages,SysUtils,Variants,Classes,Graphics,Controls,Forms,Dialogs,ExtCtrls,StdCtrls;typeTRei35=class(......