作者:dmcm0010 | 来源:互联网 | 2024-11-03 10:06
该算法旨在通过将字符串S与其逆序字符串S'逐字符比较,来生成一个非最小字典序的新字符串T。具体步骤为:从首字符开始,若S的当前字符小于S'的对应字符,则将S的首字符添加到T的末尾;反之则将S'的首字符添加到T的末尾。若两者相等,可任选其一。例如,当输入为"A"时,算法将如何处理?此方法在某些特定情况下可能无法达到预期效果,需进一步探讨其原因及优化方案。
算法是:
将字符串S与反向的字符串S'从首字母开始依次比较
S小就把S的首字母取出放入字符串T的尾部,
S'小就把S'的首字母取出放入字符串T尾部,
如果相同哪个都行。
我输入的是:A,C,D,B,C,B;输出的是A,C,B,C,D,D;
我认为最小字典序是:A.B.B.C.C.D
void solve();
char arr[6] = { 'A','C','D','D','B','C' };
int _tmain(int argc, _TCHAR* argv[])
{
solve();
system("pause");
return 0;
}
void solve()
{
int a = 0;
int b = 5;
while (a<=b){
bool left = false;
for (int i = 0; a + i<=b - i; i++)
{
if (arr[a + i]
{
left = true;
break;
}
else if (arr[a + i]>arr[b - i])
{
left = false;
break;
}
}
if (left == true)
{
cout << arr[a];
a++;
}
else
{
cout << arr[b];
b--;
}
}
}
2 个解决方案
代码功能归根结底不是别人帮自己看或讲解或注释出来的;而是被自己静下心来花足够长的时间和精力亲自动手单步或设断点或对执行到某步获得的中间结果显示或写到日志文件中一步一步分析出来的。
提醒:再牛×的老师也无法代替学生自己领悟和上厕所!
单步调试和设断点调试(VS IDE中编译连接通过以后,按F10或F11键单步执行,按Shift+F11退出当前函数;在某行按F9设断点后按F5执行停在该断点处。)是程序员必须掌握的技能之一。