我有一串数字,例如469111252,我知道如何从左侧拆分,但如何使用substr从右侧拆分?
如果digitsPerNode = 2
左起46 91 11 25 2
但我想从正确的52 12 11 69 4
获得//left hand side parse
for (int i=0;i<num.length(); i+=digitsPerNode) {
splitNum = num.substr(i,digitsPerNode);
}
答案 0 :(得分:0)
从上到下计数,而不是从下到上。
int numlength=num.length();
if(numlength%2==1)
numlength+=1;
for(int i=numlength;i>=0;i-=digitsPerNode)
{
splitNum = num.substr(i,digitsPerNode);
{
答案 1 :(得分:0)
string a = "1234567890-=4";
for (int i = a.length() - 2; i >= -1; i = i - 2)
{
if (i < 0) cout << a.substr(i+1, 1) << endl;
else cout << a.substr(i, 2) << endl;
}
答案 2 :(得分:0)
我找到了具有反向功能的解决方案
DoublyLinkedList::DoublyLinkedList(string value, string dPerNode)
{
digitsPerNode = stoi(dPerNode);
string subString;
reverse(value.begin(), value.end());
for (int i = 0; i <= value.length(); i += digitsPerNode)
{
//cut string by digitsPerNode Ex: 3 500 123 412
subString = value.substr(i, digitsPerNode);
reverse(subString.begin(), subString.end());
insertAtHead(subString);
}
}