【ZZULI】郑州轻工业大学oj 1157: 连续的n个1

博客提出一个编程问题,计算机数据由0和1组成,需找出连续n个1的子串个数。输入为一个由0和1组成、长度小于1000的字符串及一个正整数n,输出为连续n个1的子串个数,还给出了参考代码。

问题描述:

计算机数据都是由0和1组成的,看着长长的0101001110101111011,要找出连续n个1的子串有多少个,确实麻烦,请你编程实现吧。


输入:

输入第一行为一个字符串,由0和1组成,长度小于1000;输入第二行为一个正整数n。


输出:

输出一个整数,表示连续n个的1的子串的个数。


样例输入:

0101001110101111011
2

样例输出:

6

参考代码:

#include<stdio.h>
int main()
{
    const int N=1000;
    int sum=0,n,m,flag;
    char a[N];
    gets(a);
    scanf("%d",&n);
    for(int i=0;a[i]!='\0';i++)
    {
        if(a[i]=='1')
        {
            flag=0;
            for (int j = i+1;j<i+n;j++) {
                if (a[j] != '1')
                    flag=1;
            }
        }
        if(a[i]=='1'&&flag==0)
            sum++;
    }
    printf("%d\n",sum);
    return 0;
}

郑州轻工业大学在线评测系统(OJ)是一个用于程序设计学习和实践的平台,为学生和编程爱好者提供了一个在线提交代码并进行评测的环境。该平台有助于提升编程能力,检验对知识的掌握程度。 ### 平台介绍 郑州轻工业大学OJ平台网址为 acm.zzuli.edu.cn ,提供了丰富的题目资源,涵盖各类算法和编程知识点,适合不同层次的学习者进行练习和提高。其评测系统能够快速准确地对用户提交的代码进行评判,反馈代码的运行结果,如通过、错误、超时等。 ### 使用方法 用户在访问该平台后,一般需要先注册账号,登录后即可选择题目进行作答。以C语言为例,提交代码时可参考以下示例:对于简单的两数相加问题(类似郑州轻工业大学OJ 1000),代码如下: ```c #include<stdio.h> int main() { int a,b,c; scanf("%d %d", &a, &b); c=a+b; printf("%d\n",c); return 0; } ``` 对于字符统计相关问题(类似郑州轻工业大学1131 OJ),代码如下: ```c #include<stdio.h> int main() { char n,a[150]={0}; int max,i,t; while(scanf("%c",&n),n!='\n'){ if(n>='A'&&n<='Z'){ n=n+32; t=n; a[t]++; }else{ t=n; a[t]++; } } max=a[122]; for(i=122;i>=97;i--){ if(a[i]>=max) { max=a[i]; t=i; } } printf("%c",t); return 0; } ``` 在提交代码时,要注意选择正确的编程语言,将代码复制到提交框内,然后点击提交按钮等待评测结果。同时,学习过程中要避免直接复制代码,而应借鉴代码思路,自己动手编写代码,这样才能真正提高编程能力 [^4]。 ### 题目资源 平台的题目资源丰富多样,从基础的语法练习到复杂的算法实现都有涉及。题目按照不同的知识点和难度进行分类,方便用户有针对性地进行学习和练习。无论是初学者还是有一定编程基础的人,都能在该平台找到适合自己的题目进行挑战。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值