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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 联想st510开卡软件_无力吐槽的一单联想ST510固态硬盘数据恢复

    联想st510开卡软件_无力吐槽的一单联想ST510固态硬盘数据恢复接苏州IT服务商客户送修一块联想ST510固态硬盘需要恢复数据,故障现象为SSD可以正常识别,而且识别的速度也是很快的!,我们接上PC3000访问第一扇区显示代码是错误的,然后读取其它扇区就BSY状态了,必须从新断电加电才可以读取!(从经验判断这块SSD的主控应该是SM2258XT或SM2256K,PC3000SSD加载恢复的速度正常是8M每秒左右)由于这块硬盘转手次数太多(起码转了4手)也没…

    2022年9月2日
    3
  • 适合做回归分析的数据_时序数据库与实时数据库

    适合做回归分析的数据_时序数据库与实时数据库JTSGeometry关系分析:缓冲区分析(Buffer)包含所有的点在一个指定距离内的多边形和多多边形凸壳分析(ConvexHull)包含几何形体的所有点的最小凸壳多边形(外包多边形)交叉分析(Intersection)A∩B交叉操作就是多边形AB中所有共同点的集合联合分析(Union)AUBAB的联合操作就是AB所有点的集合差异分析(Diff…

    2025年6月1日
    0
  • edge开启ie兼容模式_edge ie兼容模式

    edge开启ie兼容模式_edge ie兼容模式Edge,IE浏览器兼容模式设置

    2022年9月8日
    0
  • 考研数据库系统概论题目整理总结_数据库系统概论pdf

    考研数据库系统概论题目整理总结_数据库系统概论pdf数据库系统概论题目自整理说复试题目过于牵强,只是自己整理的一些知识点而已,为了便于理解和背诵,有些部分定义和说明尽量简明扼要,如有错误请多多指教!(不可转载)1.试述数据、数据库、数据库系统、数据库管理系统的概念。(l)数据(Data):描述事物的符号记录称为数据。数据的含义称为语义,数据与其语义是不可分的。(2)数据库(DataBase,简称DB):若干个相互之间有关联关系的表的集合,表就是关系。数据库中的数据具有永久存储,易扩展,可共享的特点。(3)数据库系统(Data

    2022年9月2日
    2
  • rpm 安装及更新

    rpm 安装及更新安装rpmsudorpm-ivh/Users/aaa.bbb/rpmbuild/RPMS/x86_64/worker-0.0.1-1.x86_64.rpm–force–prefix=/home/chroot/最后prefix是指定安装路径,如果不指定,就是在根目录/rpm-qa|grept-server…

    2022年6月9日
    44
  • 大话设计模式C++实现-第22章-桥接模式

    大话设计模式C++实现-第22章-桥接模式

    2022年2月5日
    39

发表回复

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

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