免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1558 | 回复: 1
打印 上一主题 下一主题

两道算法题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-09-23 17:49 |只看该作者 |倒序浏览
1. 检查字符串b是否都被a包含。有汉字,GBK。  如果b是有字符重复,在a中出现次数也不少了在b中出现次数。
是返回1,不是返回0

int is_include(char *a,char *b)
{
}


2.seq[a,b……z,aa,ab,......,zz,aaa,aab……,zzz,aaaa,aaab……]

给任意字符串s给出在上述序列中的位置.





for(int j=strlen(s)-1,k=0;j>=0;j--,k++)
index+=seqCh[k]^j;

论坛徽章:
0
2 [报告]
发表于 2008-09-26 14:55 |只看该作者

第一个问题的代码

#include <stdio.h>
#include <string.h>

int is_include( char *s1, char *s2 );

void main(void)
{
       
        char s1[80], s2[80];

        printf("请您输入第一个字符串:\n");
        gets(s1);
        printf("请您输入第二个字符串:\n");
        gets(s2);

        if ( is_include(s1, s2) ) printf("字符串1包含字符串2。\n");
        else printf("字符串1不包含字符串2。\n");       
}

int is_include( char *s1, char *s2 )
{
        int i, j, len1, len2;
        int cnt = 0;
       

        len1 = strlen(s1);
        len2 = strlen(s2);

        for ( i = 0; i <= len1 - len2; i++ )
        {
               
                if ( s1 == s2[0] )
                {
                        for ( j = 1; j < len2; j++ )
                        {
                                if ( s1[i+j] != s2[j] )
                                {
                                        break;
                                }
                        }
                }
                if ( j == len2 ) cnt++;
        }

        if ( cnt > 0 ) return 1;
        else return 0;
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP