百度面试题:找出给定字符串对应的序号

序列Seq=[a,b,…z,aa,ab…az,ba,bb,…bz,…,za,zb,…zz,aaa,…] 类似与excel的排列,任意给出一个字符串s=[a-z]+(由a-z字符组成的任意长度字符串),请问s是序列Seq的第几个。

 

注意到每满26个就会向前进一位,类似一个26进制的问题。
比如ab,则位置为26*1 + 2;
比如za,则位置为26*26 + 1;
比如abc,则位置为26*26*1 + 26*2 + 3;

 

#include<iostream>
#include <cstdlib>

using namespace std;

unsigned int position(char *str, int len)
{
         assert(str != NULL && len > 0);
         char c = *str;
         if(len == 1) return c - 96;
        
         int i = 0;
         int col_position = str[len - 1] - 96;  // 最后一个字符的大小
         
         unsigned int zzz_position = 1;
         for(i = 0; i < len - 1; i++)
         {
               zzz_position *= 26;
         }
        
         unsigned int row_position = position(str, len - 1); // 递归
        
         return zzz_position + (row_position - 1)*26 + col_position;
}

/*
* a b c d ... z
* aa ab ac ad ... az
* ba bb bc bd ... bz
* ...
* za zb zc zd ... zz
* ...
* aaa aab aac ... aaz
* aba abb abc ... abz
* ...
* zza zzb zzc ... zzz
* aaaa ...
*/

int main()
{
    cout << position("abcd", 4) << endl;
    system("pause");
    return 0;
}

 

转载于:https://www.cnblogs.com/xulb597/archive/2012/05/12/2497317.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值