51nod官网_51nod题难度

51nod官网_51nod题难度1396 还是01串基准时间限制:1 秒空间限制:131072 KB分值: 20 难度:3级算法题 收藏 关注给定一个0-1串s,长度为n,下标从0开始,求一个位置k,满足0<=k<=n,并且子串s[0..k-1]中的0的个数与子串s[k..n-1]中1的个数相等。注意:(1)如果k=0,s[0..k-1]

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

基准时间限制:1 秒 空间限制:131072 KB 分值: 20 
难度:3级算法题

51nod官网_51nod题难度 收藏

51nod官网_51nod题难度 关注

给定一个0-1串s,长度为n,下标从0开始,求一个位置k,满足0<=k<=n, 并且子串s[0..k – 1]中的0的个数与子串s[k..n – 1]中1的个数相等。 注意:

(1) 如果k = 0, s[0..k – 1]视为空串
(2) 如果k = n, s[k..n – 1]视为空串
(3) 如果存在多个k值,输处任何一个都可以

(4) 如果不存在这样的k值,请输出-1

Input
就一行,包含一个0-1串S,长度不超过1000000。
Output
题目要求的k值
Input示例
01
Output示例
1

思路(月初第一水~):

维护两个前缀和即可。

对应枚举一个位子K。

暴力处理,时间复杂度O(n);

Ac代码:

#include<stdio.h>
#include<string.h>
using namespace std;
char a[1000500];
int cont0[1000500];
int cont1[1000500];
int main()
{
    while(~scanf("%s",a))
    {
        int n=strlen(a);
        for(int i=0;i<n;i++)
        {
            if(i==0)
            {
                if(a[i]=='0')cont0[0]=1,cont1[0]=0;
                else cont0[0]=0,cont1[0]=1;
            }
            else
            {
                cont1[i]=cont1[i-1];
                cont0[i]=cont0[i-1];
                if(a[i]=='1')cont1[i]++;
                else cont0[i]++;
            }
        }
        int flag=0;
        for(int i=0;i<=n;i++)
        {
            if(cont0[i-1]==cont1[n-1]-cont1[i-1])
            {
                flag=1;
                printf("%d\n",i);
                break;
            }
        }
        if(flag==0)printf("-1\n");
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169958.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月12日 下午12:16
下一篇 2022年8月12日 下午12:36


相关推荐

  • OpenClaw(1) 安装教程(Windows、MacOS、Linux)

    OpenClaw(1) 安装教程(Windows、MacOS、Linux)

    2026年3月13日
    3
  • 手动清除fun.xls.exe病毒的方法[通俗易懂]

    手动清除fun.xls.exe病毒的方法[通俗易懂](无法显示隐藏文件以及无法双击打开分区)用杀毒软件杀毒,所有驱动盘上的文件夹表现为不可见,实际为文件夹隐藏了。如何判断是中了该种病毒,可以通过在命令行下键入:cdC:’dir/ah如果有fun.x

    2022年7月3日
    31
  • 同源策略与跨域

    同源策略与跨域前言 最近业务上前端同学多次联系说访问腾讯云 cos 资源的时候因为跨域的问题访问不到 大致看了下腾讯云关于设置跨域访问的教程 按照前端同学给的域名等选项就给配了 而且测试下来也是好的 但是呢一直不知道什么是跨域这里就做一个简单的学习记录 一 同源策略同源策略 SameOriginPo 是一种约定 它是浏览器最核心也是最基本的安全功能 同源策略会阻止一个域的 javascrip 脚本和另一个域的内容进行交互 是用于隔离潜在恶意文件的关键安全机制 关于这一点我们后面会举例说明

    2026年3月19日
    2
  • RNN学习笔记(一)-简介及BPTT RTRL及Hybrid(FP/BPTT)算法[通俗易懂]

    RNN学习笔记(一)-简介及BPTT RTRL及Hybrid(FP/BPTT)算法[通俗易懂]RNN网络的学习算法-BPTT笔记本Markdown编辑器使用StackEdit修改而来,用它写博客,将会带来全新的体验哦:Markdown和扩展Markdown简洁的语法代码块高亮图片链接和图片上传LaTex数学公式UML序列图和流程图离线写博客导入导出Markdown文件丰富的快捷键快捷键加粗Ctrl+B斜体Ctrl+I引

    2022年6月23日
    33
  • python批量执行sql语句_python jdbc

    python批量执行sql语句_python jdbc一、前言在开发的过程中,总希望方法执行完了可以看到完整是sql语句,从而判断执行的是否正确,所以就希望有一个可以打印sql语句的插件。p6spy就是一款针对数据库访问操作的动态监控框架,他可以和数据库无缝截取和操纵,而不必对现有应该用程序的代码做任何修改。通过p6spy可以直接打印数据库执行的语句,下面向大家介绍一下p6spy。二、使用p6spy,需要什么?p6spy的ja…

    2026年4月14日
    9
  • Linux系统的镜像文件iso下载地址[通俗易懂]

    Linux系统的镜像文件iso下载地址[通俗易懂] 打开如下地址http://archive.kernel.org/centos-vault/6.1/isos/x86_64/然后选择  CentOS-6.1-x86_64-bin-DVD1.iso即可下载。

    2022年5月2日
    50

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号