HDU 3788 和九度OJ 1006测试数据是不一样的

HDU 3788 和九度OJ 1006测试数据是不一样的

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

ZOJ问题

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 2935    Accepted Submission(s): 889




Problem Description
对给定的字符串(仅仅包括’z’,’o’,’j’三种字符),推断他能否AC。

是否AC的规则例如以下:

1. zoj能AC;

2. 若字符串形式为xzojx,则也能AC,当中x能够是N个’o’ 或者为空;

3. 若azbjc 能AC,则azbojac也能AC。当中a,b,c为N个’o’或者为空;

 


Input
输入包括多组測试用例,每行有一个仅仅包括’z’,’o’,’j’三种字符的字符串,字符串长度小于等于1000。
 


Output
对于给定的字符串,假设能AC则请输出字符串“Accepted”,否则请输出“Wrong Answer”。
 


Sample Input
   
   
zoj ozojo ozoojoo oozoojoooo zooj ozojo oooozojo zojoooo

 


Sample Output
   
   
Accepted Accepted Accepted Accepted Accepted Accepted Wrong Answer Wrong Answer

 

#include<stdio.h>
#include<string.h>
char s[2001];
char s2[2001];
void check()
{
    int cnt=0;
    memset(s2,0,sizeof(s2));
    int flag1,flag2,flag3;
    flag1=flag2=flag3=-1;
    int len=strlen(s);
    if(strcmp("zoj",s)==0)
    {
        printf("Accepted\n");
        return ;
    }
    else
    {
        for(int i=0;i<len;++i)
        {
            if(s[i]!='z'&&s[i]!='o'&&s[i]!='j')
            {
                flag3=1;
                break;
            }
        }
        for(int i=0;i<len;++i)
        {
            if(s[i]=='z')
            {
                flag1=i;
                break;
            }
        }
        for(int i=len-1;i>=0;--i)
        {
            if(s[i]=='j')
            {
                flag2=i;
                break;
            }
        }
        if(flag1>flag2||flag1==-1||flag2==-1||flag3==1)
        {
            printf("Wrong Answer\n");
        }
        else
        {
             for(int i=flag1+1;i<flag2;i++){
                    if(s[i]=='o'){
                        cnt++;
                    }//统计z、j中间o的个数
             }
             if(cnt!=flag2-flag1-1||cnt==0){//推断z、j中间是否出现除o以外的字符。cnt=0是zoj中间没有出现o。不合法。
                 printf("Wrong Answer\n");
             }
             else{
                 //j后面的o的个数除以z前面的o的个数等于z和j之间的o的个数
                 if(flag1*cnt==len-flag2-1){
                     printf("Accepted\n");
                 }
                 else{
                     printf("Wrong Answer\n");
                 }
             }
        }
    }
}
int main(int argc, char *argv[])
{
    while(~scanf("%s",s))
    {
        check();
    }
    return 0;
}

版权声明:本文博客原创文章。博客,未经同意,不得转载。

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

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

(0)
上一篇 2022年1月8日 下午10:00
下一篇 2022年1月8日 下午11:00


相关推荐

  • query.uniqueResult_validationquery not set

    query.uniqueResult_validationquery not setHibernate中使用createQuery和createSQLQuery的最大区别就是前者是使用hql语句,后者使用的是sql语句

    2022年9月30日
    5
  • 数学建模——相关系数(2)——假设检验

    数学建模——相关系数(2)——假设检验文章目录一 引述二 假设检验三 对皮尔逊系数进行假设检验步骤一 引述在上一篇文章中 我们已经介绍了如何求解 Person 相关系数 那么如何解释相关系数的大小呢 事实上 如果我们只是通过相关系数大小去判断两个变量之间的相关性 这种做法是不严格的 因为对相关系数的解释依赖于具体的应用背景和目的的 因此 相比较于相关系数的大小 我们往往更关注于显著性 而求解显著性 则需要假设检验方法 二 假设检验

    2026年3月17日
    2
  • OSSIM下部署HIDS

    OSSIM下部署HIDS

    2022年3月8日
    56
  • 8000401a错误解决方式(Excel)

    8000401a错误解决方式(Excel)前一阵子做开发须要用到Excel和Word编程,本人用的是Vista系统,开发环境是VS2005和Office2007,測试无不论什么问题,但是到部署的时候出现了一些令人非常头痛的问题,老是会出现比如:检索COM类工厂中CLSID为{000209FF-0000-0000-C000-000000000046}的组件时失败,原因是出现下面错误:8000401a。的错误,在网上查…

    2022年7月25日
    11
  • 工作流管理系统简介

    工作流管理系统简介上篇文章介绍了工作流的概念和作用 这篇文章继续介绍根据工作流运转原理产生的具体工作流管理系统 nbsp nbsp nbsp nbsp 因为有许多软件开发商都有工作流产品 并且不断有新的工作流产品走入市场 市场上可选择的产品范围很大 因此每个开发商只关注产品的特殊功能 而用户可以采用不同的产品来满足不同的需求 nbsp nbsp nbsp nbsp 然而 由于各个厂商不兼容的流程控制方式 导致没有统一的规范使得不同的工作流产品协同工作

    2026年3月16日
    3
  • 文心一言AI写作怎么操作?新手必看的保姆级教程!

    文心一言AI写作怎么操作?新手必看的保姆级教程!

    2026年3月12日
    3

发表回复

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

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