A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© qddnovo 中级黑马   /  2014-6-8 14:27  /  1373 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

C,使用递归,倒序一个栈。{1,2,3,4,5}倒序之后呢是{5,4,3,2,1}.
看一下大家有没有新奇的解法。

3 个回复

正序浏览
星河鹭起 发表于 2014-6-8 21:43
#include
void change(int *num1)
{

谢谢谢谢。
回复 使用道具 举报
#include <stdio.h>
void change(int *num1)
{
    int *m,*n,*p,i;
    p=num1+4;//此用于指向中间位置数据,用于表示循环次数,4代表调换次数,总共10个数字,只需进行4次调换。
    n=num1;//n用于表示开头
    m=9+n;//m表示末尾,地址与数字只能进行加,不能减,因此再for循环中使用了m--弥补9-n。
    for(;n<=p;n++,m--)
    {
        int tamp=*n;
        *n=*m;
        *m=tamp;
    }
    return;
}

int main()
{
    int num[]={1,2,3,4,5,6,7,8,9,10};
    change(num);
    for(int i=0;i<10;i++)
    {
        printf("%d,",num[i]);
    }
    printf("\n");
}

评分

参与人数 1技术分 +1 收起 理由
傘が咲く + 1

查看全部评分

回复 使用道具 举报 1 0
#include <stdio.h>
int main()
{
int i,;
char a[5]={1,2,3,4,5},b[5];
for(i=0;i<5;i++)
{
      b[i]=a[4-i];
}
printf("%s",b);

return 0;

}


为什么没出来正确结果呢??
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马