鱼C论坛

 找回密码
 立即注册
查看: 1122|回复: 1

[已解决]如何使输出结果和输入结果分开

[复制链接]
发表于 2020-5-18 01:13:28 | 显示全部楼层 |阅读模式
30鱼币
这是测试得到的输出结果
另一个是需要的输出样式
以下是代码
#include <stdio.h>
#include <string.h>

#define M 1046527
#define NIL (-1)
#define L 14

char H[M][L];

int getChar(char ch) {
        if(ch=='A')return 1;
        else if(ch=='C')return 2;
        else if(ch=='G')return 3;
        else if(ch=='T')return 4;
        else return 0;
}

long long getKey(char str[]) {
        long long sum=0,p=1,i;
        for(i=0; i<strlen(str); i++) {
                sum+=p*(getChar(str[i]));
                p*=5;
        }
        return sum;
}

int h1(int key) {
        return key % M;
}
int h2(int key) {
        return 1+(key % (M-1));
}

int find(char str[]) {
        long long key,i,h;
        key=getKey(str);
        for(i=0;; i++) {
                h=(h1(key)+i*h2(key)) % M;
                if(strcmp(H[h],str)==0)return 1;
                else if(strlen(H[h])==0)return 0;
        }
        return 0;
}

int insert(char str[]) {
        long long key,i,h;
        key=getKey(str);
        for(i=0;; i++) {
                h=(h1(key)+i*h2(key))%M;
                if(strcmp(H[h],str)==0)return 1;
                else if(strlen(H[h])==0) {
                        strcpy(H[h],str);
                        return 0;
                }
        }
        return 0;
}

int main() {
        int i,n,h;
        char str[L],com[9];
        for(i=0; i<M; i++)H[i][0]='\0';
        scanf("%d",&n);
        for(i=0; i<n; i++) {
                scanf("%s %s",com,str);

    if( com[0] == 'i' )
    {
            insert(str);
        }
        else
        {
                if(find(str))
            {
                    printf("yes\n");
                }
                else
                {
                        printf("no\n");
                }
        }
    }
    return 0;
}
最佳答案
2020-5-18 01:13:29
#include <stdio.h>
#include <string.h>

#define M 1046527
#define NIL (-1)
#define L 14

char H[M][L];

int getChar(char ch) {
    if(ch=='A')return 1;
    else if(ch=='C')return 2;
    else if(ch=='G')return 3;
    else if(ch=='T')return 4;
    else return 0;
}

long long getKey(char str[]) {
    long long sum=0,p=1,i;
    for(i=0; i<strlen(str); i++) {
        sum+=p*(getChar(str[i]));
        p*=5;
    }
    return sum;
}

int h1(int key) {
    return key % M;
}
int h2(int key) {
    return 1+(key % (M-1));
}

int find(char str[]) {
    long long key,i,h;
    key=getKey(str);
    for(i=0;; i++) {
        h=(h1(key)+i*h2(key)) % M;
        if(strcmp(H[h],str)==0)return 1;
        else if(strlen(H[h])==0)return 0;
    }
    return 0;
}

int insert(char str[]) {
    long long key,i,h;
    key=getKey(str);
    for(i=0;; i++) {
        h=(h1(key)+i*h2(key))%M;
        if(strcmp(H[h],str)==0)return 1;
        else if(strlen(H[h])==0) {
            strcpy(H[h],str);
            return 0;
        }
    }
    return 0;
}

int main() {
    //int i,n,h;
    int i,n;
    char str[L],com[9];
    for(i=0; i<M; i++)H[i][0]='\0';
    scanf("%d",&n);

    char *result[64];
    int index = 0;
    for(i=0; i<n; i++) {
        scanf("%s %s",com,str);
        if( com[0] == 'i' )
        {
            insert(str);
        }
        else
        {
            if(find(str))
            {
                //printf("yes\n");
                result[index++] = "yes";
            }
            else
            {
                //printf("no\n");
                result[index++] = "no";
            }
        }
    }
    for(i = 0; i < index; ++i) {
        printf("%s\n", result[i]);
    }
    return 0;
}

测试的输出结果

测试的输出结果

需要的输出样式

需要的输出样式
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-5-18 01:13:29 | 显示全部楼层    本楼为最佳答案   
#include <stdio.h>
#include <string.h>

#define M 1046527
#define NIL (-1)
#define L 14

char H[M][L];

int getChar(char ch) {
    if(ch=='A')return 1;
    else if(ch=='C')return 2;
    else if(ch=='G')return 3;
    else if(ch=='T')return 4;
    else return 0;
}

long long getKey(char str[]) {
    long long sum=0,p=1,i;
    for(i=0; i<strlen(str); i++) {
        sum+=p*(getChar(str[i]));
        p*=5;
    }
    return sum;
}

int h1(int key) {
    return key % M;
}
int h2(int key) {
    return 1+(key % (M-1));
}

int find(char str[]) {
    long long key,i,h;
    key=getKey(str);
    for(i=0;; i++) {
        h=(h1(key)+i*h2(key)) % M;
        if(strcmp(H[h],str)==0)return 1;
        else if(strlen(H[h])==0)return 0;
    }
    return 0;
}

int insert(char str[]) {
    long long key,i,h;
    key=getKey(str);
    for(i=0;; i++) {
        h=(h1(key)+i*h2(key))%M;
        if(strcmp(H[h],str)==0)return 1;
        else if(strlen(H[h])==0) {
            strcpy(H[h],str);
            return 0;
        }
    }
    return 0;
}

int main() {
    //int i,n,h;
    int i,n;
    char str[L],com[9];
    for(i=0; i<M; i++)H[i][0]='\0';
    scanf("%d",&n);

    char *result[64];
    int index = 0;
    for(i=0; i<n; i++) {
        scanf("%s %s",com,str);
        if( com[0] == 'i' )
        {
            insert(str);
        }
        else
        {
            if(find(str))
            {
                //printf("yes\n");
                result[index++] = "yes";
            }
            else
            {
                //printf("no\n");
                result[index++] = "no";
            }
        }
    }
    for(i = 0; i < index; ++i) {
        printf("%s\n", result[i]);
    }
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-14 01:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表