【算法】字符串移位

问题:一个字符串可以由另一个字符串移位得到,例如abcd,可以由bcad移位得到。

问题分析

这个问题表面上说的是字符串,但是其实更进一步可以理解为两个字符数组的元素是否一致。最简单和直白的方式,无异于用两层循环的方式来进行循环判断。这是常规方案一。

还有方案二,则是需要用到数据结构,例如,将一个字符串转换成一个set。循环另一个数组,往set中插入数据,如果一直是失败的,则true。有一次插入成功了,则false。

方案

如果我们在转换一下思想,字符其实在计算机中的表现,它的实质上也是数字,比如ASCII码中,字符a是可以转换成数字97的,所以两个数组其实只要求元素之间的差的和,如果等于0就可以判断是否相等。
例如:
1,2,34 和 2,3,14
则:

1-2=-1
2-3=-1
3-1=2
4-4=0

差的和:

-1+-1+2+0=0

但是,这样只是判断了移位,并没有判断基准位置。比如,1322是可以判断成立的,因此需要增加判断两个数组的乘积是否相等。来判断基准位置是否一致。

Python 实现

def test(old,new):
    if len(old) <= 0 or len(new) <= 0 or len(old) != len(new):
        return false;    
    oldArr = map(ord, old)    
    newArr = map(ord, new)    
    total = 0
    newPro = 1
    oldPro = 1  
    for i in xrange(0,len(oldArr)):        
        total += newArr[i] - oldArr[i]
        newPro = newT * newArr[i]
        oldPro = oldT * oldArr[i]    
    if total == 0 and newPro == oldPro:        
        return True    
    else :        
        return False

if __name__ == '__main__':
    print test('13', '22')

C 语言核心实现

#include<stdio.h>
  
   int test(char[],int,char[],int);
   int main(){
       char old[]={'b','c','a','d'};
       char new[]={'a','b','c','d'};
       int result = test(old,4,new,4);
       printf("%d\n",result);
       return 0;
  }
 
  int  test(char old[],int oldLen,char new[], int newLen) {
      if(oldLen <= 0 || newLen <= 0 || oldLen != newLen){
          return 0;
      }
  
     int total = 0;
     int newPro = 1;
     int oldPro = 1;
     for(int i=0; i<oldLen; i++){
         total += (int)old[i] - (int)new[i];
         newPro = newPro * new[i];
         oldPro = oldPro * old[i];
      }
 
    if(total == 0 && newPro == oldPro){
         return 1;
    }
    return 0;
}                  

局限

我所写实现依赖于ASCII码,当如果字符串是Unioncode编码的字符,则就会出现问题。容我有空去研究一下,相处通用得解决方案。如有问题欢迎各位批评指正,不胜感激。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,191评论 0 4
  • 前言 本文是题主准备面试时记录下的笔记整理而来,稍显粗陋,还请各位撸友勿喷哈! Topic 目录数组字符串链表二叉...
    rh_Jameson阅读 1,725评论 2 63
  • 2016下半年,你们都说我变了,甚至连我自己都有所察觉到自己的变化还蛮大。我好像已经跟自己告别,却不是好好地跟自己...
    唐伟诗阅读 305评论 0 0
  • 觉得一切都是在保佑着的进行,本觉得得力集团进不了,没想到还能那么一个位置,虽然不对口但是满足了,做人不能太贪心。他...
    fangyuanjili阅读 184评论 0 0
  • 这天半夏要去帮朋友带一节晚课,上课的地方离半夏的家有两个小时的路程,晚上半夏没有回家,去了离上课的地方...
    清空妙有阅读 290评论 2 1