您的位置:

一本通oj详解

一、一本通oj官网

一本通oj是中国最早的在线编程兴趣小组,其官网(https://www.acw1x.com/)提供了丰富的编程资源,包括提供题目的在线judge,公开的代码库,论坛等。在学习编程的过程中,一本通oj官网是一个非常好的去处。

二、一本通主账户借方已冻结

一本通oj官网的服务非常好,但是有时候会遇到像“一本通主账户借方已冻结”这样的问题。这通常是由于主账户违反了一定的规则,或者是在使用某些功能时出现了问题。如果您遇到这样的问题,可以通过一本通oj官网提供的联系方式来解决问题。

三、一本通答案

一本通oj官网提供了海量的题目,但是有时候我们可能会卡在一些疑难杂症上。这时候,一本通答案(http://www.acmer.top/)就可以发挥作用了。一本通答案里面有很多题目的解答,如果您遇到了卡壳的问题可以前往寻找答案。

四、一本通书

如果您是初学者,建议您阅读《信息学奥赛一本通》——这是一本非常优秀的编程入门书。这个项目已经在一本通oj官网内开源,可以自行下载并阅读。如果您想要提高自己的编程水平,建议您好好阅读一下这本书。

五、一本通题解

一本通oj官网有很多用户都会在上面发表题解,如果您遇到一些比较难的题目,可以先尝试阅读一下其他用户的题解来获得一些建议。当然,如果您自己找出了高效的解法,也不要忘记分享给大家哦。

六、信息学一本通题库答案

#include
using namespace std;
int main(){
    cout<<"Hello, world!"<
   

    

一本通oj官网上的题目非常多,而且难度也不一。如果您遇到了这样的问题,可以参考一下这个题解库:https://www.luogu.com.cn/problem/solution/UVA567。里面涵盖了非常全面而且详尽的答案库,可以帮助您顺利通过各种高难度的题目。

七、信息学奥赛一本通c语言版

#include 
int main()
{
    printf("Hello, world!");
    return 0;
}

     

对于c语言爱好者,可以参考信息学奥赛一本通c语言版,不仅仅包含了重要的算法和数据结构,还提供了非常多的例题供您实际操作。如果您正在使用c语言学习编程,那么这本书的参考价值非常高。

八、信息奥赛一本通例题3.9

//P5201  
#include
#include
      
#include
       
using namespace std;
const int N=1e3+10,M=1550+M,num=1e6+10,INF=2147483646;
int n,m,start,end;
int head[N],nxt[M],to[M],w[M],cnt=1;
queue
         q;
int deg[N],vis[N],dis[N],pos[num];
void read(int &x){
    x=0;char ch=getchar();
    while(ch<'0'||ch>'9')ch=getchar();
    while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
}
void add(int u,int v,int d){
    nxt[++cnt]=head[u];
    head[u]=cnt;
    to[cnt]=v;
    w[cnt]=d;
}
void init(){
    read(n),read(m);start=n+1,end=start+1;
    int a,b,c,d;p=read(p);
    for(int i=1;i<=p;i++){
        read(a),read(b),read(c),read(d);
        pos[a]=++pos[0];add(pos[a],pos[b],c);add(pos[a],pos[d]+1,-c);
    }
    for(int i=1;i<=num;i++)add(pos[i],pos[i-1],0);
    for(int i=1;i<=num;i++)add(pos[i-1],pos[i],1);
    pos[num+1]=++pos[0];
    for(int i=1;i<=num;i++)add(pos[i-1],pos[i],0);
    for(int i=1;i<=num;i++)add(pos[i],pos[i-1],1);
}
void bfs(){
    memset(vis,0,sizeof(vis));
    memset(dis,0,sizeof(dis));dis[start]=INF;vis[start]=1;
    q.push(start);
    while(!q.empty()){
        int u=q.front();q.pop();
        for(int i=head[u];i;i=nxt[i]){
            if(w[i]){
                int v=to[i];
                dis[v]=dis[u]+1;
                if(!vis[v]){
                    vis[v]=1;
                    q.push(v);
                }
            }
        }
    }
}
int dfs(int u,int flow){
    if(u==end)return flow;
    int ans=flow;
    for(int i=head[u];i&&ans;i=nxt[i]){
        if(w[i]){
            int v=to[i];
            if(dis[v]==dis[u]+1){
                int k=dfs(v,min(w[i],ans));
                if(!k)dis[v]=0;
                ans-=k;
                w[i]-=k;w[i^1]+=k;
            }
        }
    }
    if(ans)dis[u]=0;
    return flow-ans;
}
int dinic(){
    int res=0,flow;
    while(1){
        bfs();
        if(!vis[end])return res;
        while(flow=dfs(start,INF))res+=flow;
    }
}
void print(int x){
    if(x==0)return;
    if(x==start||x==end){printf("%d",x%N);return;}
    if(pos[x]==pos[x-1])print(x-1);
    else printf("%d ",x-pos[x-1]);
}
void work(){
    printf("%d\n",dinic());print(start);printf(" ");
    for(int u=1;u<=n;u++){
        for(int i=head[pos[u]];i;i=nxt[i]){
            int v=to[i];
            if(pos[v]==pos[u]&&w[i]==0&&w[i^1]==1)printf("%d ",v-pos[v-1]);
        }
    }
}
int main(){
    init();
    work();
    return 0;
}

        
       
      
     

文章末尾,附一份信息学奥赛一本通例题3.9的算法代码示例,供读者参考。

九、一本通app

一本通oj的app为用户提供了非常快捷的操作方式,可以随时随地解答编程相关的问题。如果您经常需要出门或者需要移动端进行操作,不妨将一本通oj app安装到您的手机中。一本通app中的操作和网页版十分相似,具有非常好的用户体验。