The Perfect Stall(最大流+建图)

博客围绕http://poj.org/problem?id=1274题目展开,题意为n头牛、m个谷仓,每头牛只愿去特定谷仓产奶,求可产奶的牛数量。题解给出两种方法,可用最大流构建模型,建立超级源点和汇点求解,也提到二分图可解但作者不会。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

http://poj.org/problem?id=1274

题意:n头牛 m个谷仓,一头牛只愿意去 一个固定的谷仓产奶(牛喜欢好几个谷仓),问有多少头牛可以去产内

题解:最大流写,想着尽量占满谷仓构建模型,建立超级源点 超级汇点,源点连接所有牛 ,  牛连接喜欢的谷仓,  谷仓连接汇点 ,然后跑就行了

二分图也可以写,我不会

#include<cstdio>
#include<cstring>
#include<string.h>
#include<algorithm>
#include<iostream>
#include<stdlib.h>
#include<queue> 
using namespace std;
typedef long long LL;
const int N = 20005;
const int INF = 0x3f3f3f3f;
bool vis[N];
struct Edge{
    int to, cap, flow, next;
}edge[N*50];
int n, m, cnt;//n是点 m是边 cnt是加边操作后的边 
int head[N];//邻接表 
int dis[N];//分层 等级 
int  cur[N];//弧优化 
void add(int u, int v, int w){
    edge[cnt] = (struct Edge){v, w, 0, head[u]};
    head[u] = cnt++;
    edge[cnt] = (struct Edge){u, 0, 0, head[v]};
    head[v] = cnt++;
}
 
bool bfs(int start, int endd){//分层 
    memset(dis, -1, sizeof(dis));
    memset(vis, false, sizeof(vis));
    queue<int>que;
    dis[start] = 0;
    vis[start] = true;
    que.push(start);
    while(!que.empty()){
        int u = que.front();
        que.pop();
        for(int i = head[u]; i != -1; i = edge[i].next){
            Edge E = edge[i];
            if(!vis[E.to] && E.flow<E.cap){
                dis[E.to] = dis[u]+1;
                vis[E.to] = true;
                if(E.to == endd) return true;
                que.push(E.to);
            }
        }
    }
    return false;
}
 
int dfs(int x, int res, int endd){ //增广 
	if(x == endd || res == 0) return res;
	int flow = 0, f;
	for(int& i = cur[x]; i != -1; i = edge[i].next){
		Edge E = edge[i];
		if(dis[E.to] == dis[x]+1){
		    f = dfs(E.to, min(res, E.cap-E.flow), endd);
            if(f>0){
                edge[i].flow += f;
                edge[i^1].flow -= f;
                flow += f;
                res -= f;
                if(res == 0) break;
            }
		}
	}
	return flow;
}

int max_flow(int start, int endd){
	
    int flow = 0;
    while(bfs(start, endd)){
        memcpy(cur, head, sizeof(head));//初始化弧优化数组 
        flow += dfs(start, INF, endd);
    }
    return flow;
}
 
void init(){//初始化 
    cnt = 0;
    memset(head, -1, sizeof(head));
}
int main(){

	int na,nb;
	while(cin>>na>>nb){
	init();
	int sp=0;//超级源点 
	int tp=na+nb+1;//超级汇点 
	for(int i=1;i<=na;i++){
		add(sp,i,1);//源点与 牛连边 
		int k;
		cin>>k;
		for(int j=1;j<=k;j++){
			int x;
			cin>>x;
			add(i,na+x,1);//牛与谷仓连边 
		}
	}
	for(int j=1;j<=nb;j++){
		add(na+j,tp,1);//谷仓与汇点连边 
	}	    
	int ans=max_flow(sp,tp);
	cout<<ans<<endl;
    }
    return 0;
} 

 

### RCU Stall 的概念及其处理 RCU(Read-Copy Update)是一种用于多线程环境下的同步机制,在 Linux 内核中被广泛使用。当发生 RCU stall 时,意味着某个 CPU 或者任务长时间处于一种状态,阻止了 RCU grace period 的完成[^1]。 #### RCU Stall 的检测流程 在内核中,`rcu_sched_clock_irq()` 是触发 RCU stall 检测的一个重要函数。它通过调用一系列子函数来确认是否存在 stalled CPUs 并打印相关信息。以下是其主要路径: - `rcu_sched_clock_irq()` 调用了 `rcu_pending()` 来检查是否有未决的 RCU 工作项。 - 如果存在未决工作,则进一步调用 `check_cpu_stall()` 进行更详细的分析。 - 当发现确实存在 stalled CPUs 时,会依次调用 `print_cpu_stall()` 和其他辅助函数(如 `rcu_dump_cpu_stacks()`、`dump_cpu_task()` 等),最终生成堆栈回溯信息以便调试[^2]。 #### 处理策略 针对 RCU stall 的情况,可以通过调整内核参数来进行控制。例如,`sysctl_panic_on_rcu_stall` 参数决定了系统是否应在检测到 RCU stall 后立即崩溃并记录日志。如果该值设置为 true (`1`) ,那么一旦检测到 stall 将直接引发 kernel panic,并显示 “RCU Stall” 错误消息。 另外需要注意的是,尽管上述讨论集中在 RCU stalls 上,但在现代操作系统中有许多类似的性能瓶颈现象可以利用 Pressure Stall Information (PSI) 技术监测。PSI 提供了一种方法用来衡量由于资源竞争而导致的任务延迟程度,并且能够持续一段时间维持活跃状态以减少波动影响[^3]。 对于您提到的关于 ID 级寄存器 rs1 和 rs2 修改选项部分,这似乎涉及到了指令流水线设计中的数据前馈问题以及如何选择合适的数据源作为操作数输入给后续阶段使用的问题[^4]。不过这部分内容与前面所描述的 RCU stall 主题关联不大。 ```c // 示例代码展示如何启用 sysctl_panic_on_rcu_stall 参数 #include <linux/sysctl.h> static struct ctl_table rcu_sysctls[] = { { .procname = "panic_on_rcu_stall", .data = &sysctl_panic_on_rcu_stall, .maxlen = sizeof(int), .mode = 0644, .proc_handler = proc_dointvec_minmax, .extra1 = SYSCTL_ZERO, .extra2 = SYSCTL_ONE, }, }; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值