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; }
本文介绍了一种用于生成特定格式的字母数字(称为Jam数字)的算法。该算法接受最小和最大的字母序号以及数字的位数作为输入,并生成紧随给定Jam数字之后的五个合法的Jam数字。文章详细解释了算法的工作原理并提供了实现代码。
746

被折叠的 条评论
为什么被折叠?



