jam计数法(华为入职前练习)

Jam是个喜欢标新立异的科学怪人。他不使用阿拉伯数字计数,而是使用小写英文字母计数,他觉得这样做,会使世界更加丰富多彩。在他的计数法中,每个数字的位数都是相同的(使用相同个数的字母),英文字母按原先的顺序,排在前面的字母小于排在它后面的字母。我们把这样的“数字”称为Jam数字。在Jam数字中,每个字母互不相同,而且从左到右是严格递增的。每次,Jam还指定使用字母的范围,例如,从2到10,表示只能使用 {b,c,d,e,f,g,h,i,j}这些字母。如果再规定位数为5,那么,紧接在Jam数字“bdfij”之后的数字应该是“bdghi”。(如果我们用U、V依次表示Jam数字“bdfij”与“bdghi”,则U,且不存在Jam数字P,使U)。你的任务是:对于从文件读入的一个Jam数字,按顺序输出紧接在后面的5个Jam数字,如果后面没有那么多Jam数字,那么有几个就输出几个。

Input

输入有2行,第1行为3个正整数,用一个空格隔开:

s t w

(其中s为所使用的最小的字母的序号,t为所使用的最大的字母的序号。w为数字的位数,这3个数满足:1≤s≤26, 2≤w≤t-s )

第2行为具有w个小写字母的字符串,为一个符合要求的Jam数字。

所给的数据都是正确的,不必验证。

Output
输出最多为5行,为紧接在输入的Jam数字后面的5个Jam数字,如果后面没有那么多Jam数字,那么有几个就输出几个。每行只输出一个Jam数字,是由w个小写字母组成的字符串,不要有多余的空格。
Sample Input
2 10 5
bdfij
Sample Output
bdghi
bdghj
bdgij
bdhij
befgh
 
 
#include "stdafx.h"
#include "iostream"
#include "string"
using namespace std;

/*
功能:对输入的字符串进行处理,输出符合Jam记数法的字符串
    
输入参数:
	 	Char InMinSeq:输入最小的字母的序号
		char InMaxSeq: 输入最大的字母的序号
		int InNumbLen: 输入字符的位数
        char InChaStr: 输入具有InNumbLen个字符的字符串
输出参数(指针指向的内存区域保证有效):
	 	char* pBufOutData:输出转换后的字符列表,以‘\n’区分
返回值
		void

*/


void GetResult(int InMinSeq, int InMaxSeq, int InNumbLen, char *InChaStr, char *pBufOutData)
{
	char start='a'+InMinSeq-1;
	char end='a'+InMaxSeq-1;
	
	int i,j;
	char c;
	
	for (i=0;i<5;i++)
	{
		int change_index=InNumbLen-1,count=0;   //change_index记录开始改变的位置;
		while (InChaStr[change_index] == end+change_index-InNumbLen+1) //从输入的最后一个字符依此跟最大的比较
		{
			change_index--;
			count++;
			if (change_index<0)  //如果输入字符为最大,直接return
				return;
		}
		strcpy(pBufOutData+i*(InNumbLen+1),InChaStr);  //(编译的时候出warning,忽略之)
		c=pBufOutData[change_index+i*(InNumbLen+1)]+1;  //用char c记录要改变的输出字符
		for (j=change_index+i*(InNumbLen+1);j<InNumbLen+i*(InNumbLen+1);j++)
		{
			pBufOutData[j]=c;
			c++;
		}
		pBufOutData[j]='\0';  //先赋字符串结尾符,方便将本次得到的字符strcpy到下次for循环的输入
		
		if ((count+1==InNumbLen) || i==4)//如果当前是最大的或者是第五次输出,则结束
		{
			continue;
		}
		strcpy(InChaStr,pBufOutData+i*(InNumbLen+1));
		pBufOutData[j]='\n';
	}
} 

int main()
{
	char str1[30] = "bdfij",str2[30] = "\0";  //bcde fghij  
	GetResult(2,10,5,str1,str2);
	cout<<str2;

	return 0;
}





  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值