| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 839 人关注过本帖
标题:求指错误,实现长度为 n 的数组以相反的顺序存放并输出~
只看楼主 加入收藏
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
结帖率:90.24%
收藏
已结贴  问题点数:10 回复次数:12 
求指错误,实现长度为 n 的数组以相反的顺序存放并输出~
#include<stdio.h>
#include<stdlib.h>
void main()
{
void ex(int a[],int n);
int *a;
int i,n;
puts("输入数组长度为:");
scanf("%d',&n);
a=(int*)malloc(n*4);
for(i=0;i<n;i++)
{
scanf("%d",a[i]);
}
ex(a,n);
for(i=0;i<8;i++)
printf("%d\t",*(a+i));
printf("\n");
}

void ex(int a[],int n)
{
int i,z;
for(i=0;i<n;i++)
{
    z=*(a+i);
    *(a+i)=*(a+8-1-i);
    *(a+8-1-i)=z;
}  
}

例如数组a(7)={1,2,3,4,5,6,7}对应的输出数组为{7,6,5,4,3,2,1}
编译说一直有错误,求大神明点~
搜索更多相关主题的帖子: include 
2014-10-11 14:43
hackrol
Rank: 4
来 自:世界和平组织
等 级:业余侠客
帖 子:62
专家分:267
注 册:2014-9-6
收藏
得分:10 
发现第一个错误 ,第一个scanf 里面的双引号不完整,再看看后面的!

发现第二个错误 ,第二个scanf里的没有用&取地址!

发现第三个错误 ,ex函数从头到尾都交换一次,所以相当于没有交换,应该只交换一半!所以for应该改成这样

程序代码:
for(i=0;i<=n/2;i++)
    {
        z=*(a+i);
        *(a+i)=*(a+n-i-1);
        *(a+n-i-1)=z;
    }    


[ 本帖最后由 hackrol 于 2014-10-11 15:24 编辑 ]
2014-10-11 15:03
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
以下程序功能得以实现:
#include<stdio.h>
#include<stdlib.h>
int m;
void main()
{
void ex(int a[],int n);
int *a;
int i,n1;
puts("输入数组长度为:");
scanf("%d",&m);
a=(int*)malloc(m*4);
for(i=0;i<m;i++)
{
scanf("%d",a+i);
}
n1=int(m/2);
ex(a,n1);
for(i=0;i<m;i++)
printf("%d\t",*(a+i));
printf("\n");
}

void ex(int a[],int n)
{
int i,z;
for(i=0;i<n;i++)
{
    z=*(a+i);
    *(a+i)=*(a+m-1-i);
    *(a+m-1-i)=z;
}  
}

[ 本帖最后由 S140131022 于 2014-10-11 15:26 编辑 ]

既然还有不甘心
就还没到放弃的时候~
2014-10-11 15:24
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
回复 2 楼 hackrol
谢谢~我做出来了·

既然还有不甘心
就还没到放弃的时候~
2014-10-11 15:25
hackrol
Rank: 4
来 自:世界和平组织
等 级:业余侠客
帖 子:62
专家分:267
注 册:2014-9-6
收藏
得分:0 
回复 4 楼 S140131022
最好把malloc(n*4) 改成 malloc(n*sizeof(int))
2014-10-11 15:28
书生等待
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:8
帖 子:280
专家分:689
注 册:2013-2-22
收藏
得分:0 
哈哈,在这还能遇到重邮的妹子

#include<stdio.h>
#include<stdlib.h>
void main()
{
void ex(int a[],int n);
int *a;
int i,n;
puts("输入数组长度为:");
scanf("%d",&n);
a=(int*)malloc(n*sizeof(int));
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}

ex(a,n);
for(i=0;i<n;i++)
printf("%d\t",*(a+i));
printf("\n");
}

void ex(int a[],int n)
{
int i,z;
for(i=0;i<=n/2;i++)//这里因为你是前后交换,所以只要循环次数到数组长度的一半就行了,循环体里边的8应该是n吧
{
    z=*(a+i);
    *(a+i)=*(a+n-1-i);
    *(a+n-1-i)=z;
}
}

[ 本帖最后由 书生等待 于 2014-10-11 15:44 编辑 ]
2014-10-11 15:43
廉价的咖啡
Rank: 2
来 自:湖北 荆门
等 级:论坛游民
威 望:2
帖 子:53
专家分:17
注 册:2014-10-9
收藏
得分:0 
还有较简单的程序也可实现  你所说的要求哦。
# include <stdio.h>
# include <malloc.h>

int main(void)
{
    int i, len;
    int * p;

    p = (int *)malloc(sizeof(int));
   
    printf("请输入数组的长度, len = ");
    scanf("%d", &len);

    for(i=0; i<len; i++)
    {
        printf("请输入第%d个数的值:\n", i+1);
        scanf("%d", &p[i]);
    }

    printf("原输入的值:\n");
    for(i=0; i<len; i++)
    {
        printf("%d  ",p[i] );
    }
        printf("\n");

    printf("反向输出值:\n");
    for(i=len-1; i>=0; i--)
    {
        printf("%d  ",p[i] );
    }
        printf("\n");

    return 0;

}

就在这一刻,你的对手依旧不停的翻动书页。
2014-10-11 18:04
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
三个人四门成绩:计算其总平均分,查看指定人的成绩,两门不及格就要重修,这需要重修的人是:(程序如下:)

#include<stdio.h>
int m;
void main()
{
float fun1(int *x);
void fun2(int *x,int n);
void fun3(int *x);
float avarage;   
int a[3][4],i,j,n,*x;
x=a[0];
printf("Input your arrage:\n");
for(j=0;j<3;j++)
{
for(i=0;i<4;i++)
scanf("%d",a[j]+i);
}
m=sizeof(a)/4;
avarage=fun1(x);
printf("The avarage is:%7.2f\t",avarage);
printf("\n");
printf("you want to search the grades of number:");
scanf("%d",&n);
fun2(x,n);
printf("The failure is :");
fun3(x);
printf("\n");
}


float fun1(int *x)
{
    float sum=0;
    int i;
    for(i=0;i<m;i++)
    sum=sum+*(x+i);
    return sum/m;
}
void fun2(int *x,int n)
{
int i;
printf("the grades is:");
for(i=0;i<4;i++)
printf("%d\t",*(x+4*(n-1)+i));
printf("\n");
}
void fun3(int *x)
{
    int j,i,m=0;
    for(j=0;j<3;j++)
    {
    for(i=0;i<4;i++)
    {
    if(*(x+4*j+i)<60)m++;
    if(m>=2)
    {
        printf("%d\t",j+1);
        break;
    }
    }
    m=0;
    }

}

既然还有不甘心
就还没到放弃的时候~
2014-10-11 19:01
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
回复 8 楼 S140131022
谁能更简单的实现吗?感觉很复杂~

既然还有不甘心
就还没到放弃的时候~
2014-10-11 19:02
S140131022
Rank: 2
来 自:重庆邮电大学
等 级:论坛游民
帖 子:205
专家分:35
注 册:2014-10-9
收藏
得分:0 
回复 5 楼 hackrol
嗯嗯 这个我懂的~3q

既然还有不甘心
就还没到放弃的时候~
2014-10-11 19:03
快速回复:求指错误,实现长度为 n 的数组以相反的顺序存放并输出~
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016904 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved