Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1795404
  • 博文数量: 306
  • 博客积分: 3133
  • 博客等级: 中校
  • 技术积分: 3932
  • 用 户 组: 普通用户
  • 注册时间: 2009-04-19 16:50
文章分类

全部博文(306)

文章存档

2018年(7)

2017年(18)

2016年(39)

2015年(35)

2014年(52)

2013年(39)

2012年(22)

2011年(29)

2010年(53)

2009年(12)

分类: C/C++

2012-09-13 15:30:49

如果两个字符串的字符一样,但是顺序不一样,被认为是兄弟字符串,问如何在迅速匹配兄弟字符串(如,bad和adb就是兄弟字符串)

若是兄弟,则str1和str2必须最少遍历一遍;若不是兄弟,则可以提前终止遍历。


int func(char *str1, char *str2)
{
    // ASCII nums
    int i, j, count[128];
    char *p1, *p2;
    p1 = str1;
    p2 = str2;
    j = 0;
    // initial array
    for(i=0; i<128; i++)
        count[i] = 0;
    while('\0' != *p1)
    {
        count[*p1++]++;
        j++;
    }
    while('\0' != *p2)
    {
        count[*p2]--;
        j--;
        if(j < 0 || count[*p2] < 0)
            return 0;
        p2++;
    }
    // check 0
    for(i=0; i<128; i++)
    {
        if(count[i] != 0)
            return 0;
    }
    return 1;
}

  


1分2分5分的硬币,组成1角,共有多少种组合。
一个O(1)的算法吧,欢迎大家讨论

    // n:钱数,单位:"角" 
    int f(int n) 
    { 
       return 5*n*n+4*n+1;  
    }

阅读(2679) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~