字符串分割并倒序的问题

纯冰糖 2011-08-08 04:14:13
char * s="12345";
如何转成 "452301" 这样的字符串?
就是说最后一位如果只有一个字符或数字,前补0
...全文
256 22 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
22 条回复
切换为时间正序
请发表友善的回复…
发表回复
纯冰糖 2011-08-09
  • 打赏
  • 举报
回复
嗯,昨天下班前没来得及回复,自己用指针解决了,谢谢大家了。
beijidebaizhou 2011-08-08
  • 打赏
  • 举报
回复
用指针解决啊!
Eleven 2011-08-08
  • 打赏
  • 举报
回复
char* s = "12345";
int len = strlen(s);

char* buf = NULL;
bool bOdd = false;
bOdd = len % 2 ? true : false;
if(bOdd)
{
buf = new char[len+2];
buf[0] = '0';
strcpy(&buf[1], s);
}
else
{
buf = new char[len+1];
strcpy(&buf[0], s);
}

int i = 0;
int j = strlen(buf) - 1;
while(i < j)
{
char ch = buf[i];
buf[i] = buf[j];
buf[j] = ch;
++i;
--j;
}

char* p = buf;
while('\0' != *p)
{
char ch = *p;
*p = *(p+1);
*(p+1) = ch;
p += 2;
}

AfxMessageBox(CString(buf));
delete[] buf;
buf = NULL;
gz_qmc 2011-08-08
  • 打赏
  • 举报
回复
睁大你的熊猫眼看清楚了:

char *s="12345902845298475923485\0"; /*注意,要\0结束尾*/
char *p=s;
char buf[1024]={0}; /*结果*/
char *q=buf;

while(*p) p++; /*挪到屁股*/
p--; /*对准屁眼*/
while(1)
{
if(p==s)
{
*q='0';
*(q+1)=*p;
break;
}
else
{
*q=*(p-1);
*(q+1)=*p;
if((p-1)==s) break;
else
{
q+=2;
p-=2;
}
}
}

schlafenhamster 2011-08-08
  • 打赏
  • 举报
回复
strcpy(tmp,"000000");
strcat(tmp,s);
strcpy(tmp,&tmp[strlen(tmp)-6]);// 取右边6个 !
这3句保证6个字符长
纯冰糖 2011-08-08
  • 打赏
  • 举报
回复
[Quote=引用 16 楼 schlafenhamster 的回复:]
也可以:
char *s="12345";
char tmp[20];
strcpy(tmp,"000000");
strcat(tmp,s);
strcpy(tmp,&tmp[strlen(tmp)-6]);
char tmp1[20];
memset(tmp1,0,20);
memcpy(&tmp1[0],&tmp[4],2);
memcpy(&……
[/Quote]

长度不一定是五位,最长6位.
schlafenhamster 2011-08-08
  • 打赏
  • 举报
回复
也可以:
char *s="12345";
char tmp[20];
strcpy(tmp,"000000");
strcat(tmp,s);
strcpy(tmp,&tmp[strlen(tmp)-6]);
char tmp1[20];
memset(tmp1,0,20);
memcpy(&tmp1[0],&tmp[4],2);
memcpy(&tmp1[2],&tmp[2],2);
memcpy(&tmp1[4],&tmp[0],2);
纯冰糖 2011-08-08
  • 打赏
  • 举报
回复
[Quote=引用 14 楼 schlafenhamster 的回复:]
CString tmp="000000"+s;
tmp=tmp.Right(6);
tmp=tmp.Right(2)+tmp.Mid(2,2)+tmp.Left(2);
[/Quote]

不使用MFC的,纯C的代码
schlafenhamster 2011-08-08
  • 打赏
  • 举报
回复
CString tmp="000000"+s;
tmp=tmp.Right(6);
tmp=tmp.Right(2)+tmp.Mid(2,2)+tmp.Left(2);
纯冰糖 2011-08-08
  • 打赏
  • 举报
回复
[Quote=引用 11 楼 buyong 的回复:]
你估计也不能用stl里的string吧。那就自己写个函数操作char[]数据吧
[/Quote]

stl用不了的
纯冰糖 2011-08-08
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 buyong 的回复:]
我没看懂,如果原先是54321,转换后是什么?原先是10000呢?

引用楼主 rouqing 的回复:
char * s="12345";
如何转成 "452301" 这样的字符串?
就是说最后一位如果只有一个字符或数字,前补0
[/Quote]

54321-21 43 05 //5前补0
10000-00 00 01

两位两位转的
buyong 2011-08-08
  • 打赏
  • 举报
回复
你估计也不能用stl里的string吧。那就自己写个函数操作char[]数据吧
buyong 2011-08-08
  • 打赏
  • 举报
回复
我没看懂,如果原先是54321,转换后是什么?原先是10000呢?
[Quote=引用楼主 rouqing 的回复:]
char * s="12345";
如何转成 "452301" 这样的字符串?
就是说最后一位如果只有一个字符或数字,前补0
[/Quote]
纯冰糖 2011-08-08
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 cityhunter_bj 的回复:]
有专门的函数吗?
估计要自己写了
[/Quote]

没有直接的函数,想了半天,还在试验……
cityhunter_bj 2011-08-08
  • 打赏
  • 举报
回复
有专门的函数吗?
估计要自己写了
纯冰糖 2011-08-08
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 schlafenhamster 的回复:]
char * s="12345";
如何转成 "452301"

都是数字?
[/Quote]

纯数字,金额去掉小数点了,原来是123.45元。
schlafenhamster 2011-08-08
  • 打赏
  • 举报
回复
char * s="12345";
如何转成 "452301"

都是数字?
纯冰糖 2011-08-08
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 shenyi0106 的回复:]
作业题?
建立个临时字符数组,然后反向找s,按照你的要求应该是每次找两个字符,然后做处理放到临时字符数组中
就这样
[/Quote]

硬件返回的数据,非得要这样颠倒一下才成。
shenyi0106 2011-08-08
  • 打赏
  • 举报
回复
作业题?
建立个临时字符数组,然后反向找s,按照你的要求应该是每次找两个字符,然后做处理放到临时字符数组中
就这样
纯冰糖 2011-08-08
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 work1s 的回复:]
干嘛不用CString类型?用CString来处理就简单了
[/Quote]

没有用到MFC编写代码
加载更多回复(2)

16,548

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧