| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 753 人关注过本帖
标题:结果为什么出错
只看楼主 加入收藏
liuxiaodong
Rank: 1
等 级:新手上路
帖 子:23
专家分:6
注 册:2010-3-26
结帖率:42.86%
收藏
已结贴  问题点数:20 回复次数:9 
结果为什么出错
有n个整数,使前面各数顺序向后移m个位置,最后m个数变成最前面m个数。(用指针实现)
运行时出现Divide error,不知道为什么,请大家指导一下.
#include <stdio.h>
#define N 10
int fun (int *p, int n, int m)
{
    int i, t, k = 2;
    for (i = 0; i < n - m; i++)
    {
        k = i % k;
        t = *p;
        *p = *(p+n-m+k);
        *(p+n-m+k) = t;
    }
}
void main ()
{
    int i, m, a[N];
    printf ("please enter number:");
    for (i = 0; i < N; i++)
    {
        scanf ("%d", &a[i]);
    }
    printf ("please input m(m < 10):");
    scanf ("%d", &m);
    fun (a, N, m);
    for (i = 0; i < N; i++)
    {
        printf ("%d", a[i]);
    }
}
搜索更多相关主题的帖子: 结果 
2010-05-15 22:30
yjj634041926
Rank: 2
等 级:论坛游民
帖 子:36
专家分:76
注 册:2010-4-15
收藏
得分:4 
我明天帮你看  我要睡觉了  不好意思啊。。。。。。。。。。。。。。
2010-05-15 22:51
无悔爱白修
Rank: 2
等 级:论坛游民
帖 子:28
专家分:27
注 册:2010-3-24
收藏
得分:4 
你写的函数fun(),我真的是看不懂.好象实现不了什么嘛.
我写了一个程序,看看是不是你需求的样子的:
#include <stdio.h>

void move(int *a,int b)
{
    int i,num;
    num = a[b-1];
    for(i=b-2;i>=0;i--)
    {
        *(a+i+1) = *(a+i);
    }
    a[0] = num;
}

void main()
{
    int i,str[10],n;
   
    printf("please input 10 numbers:\n");
    for(i=0;i<10;i++)
        scanf("%d",&str[i]);

    printf("/**********************/\n");
   
    printf("input your m:\n");
    scanf("%d",&n);

    for(i=0;i<n;i++)
        move(str,10);

    printf("/***********************/\n");
    for(i=0;i<10;i++)
        printf("%d ",str[i]);
    printf("\n");
}
2010-05-15 22:58
liuxiaodong
Rank: 1
等 级:新手上路
帖 子:23
专家分:6
注 册:2010-3-26
收藏
得分:0 
回复 3楼 无悔爱白修
能说一下你的算法吗
2010-05-16 09:50
无悔爱白修
Rank: 2
等 级:论坛游民
帖 子:28
专家分:27
注 册:2010-3-24
收藏
得分:0 
回复 4楼 liuxiaodong
就是先把最后一个先保存,然后从尾开始,一个一个向后复制.
2010-05-16 19:16
yjj634041926
Rank: 2
等 级:论坛游民
帖 子:36
专家分:76
注 册:2010-4-15
收藏
得分:0 
你的那个程序只能运行一半就出现问题。。。后面函数的调用根本没有起到作业。。。。
2010-05-16 20:52
蓝色宁静
Rank: 1
等 级:新手上路
帖 子:17
专家分:5
注 册:2010-4-5
收藏
得分:4 
你那个我没看明白,我写了一个,你看看

#include<stdio.h>
#define N 10
void main()
{
    void shift(int *x,int);
    int a[N],*p,i,m;
    p=a;
    for(i=0;i<N;i++)
        scanf("%d",p++);
    printf("移动的位数:\n");
    scanf("%d",&m);
    p=a;
    shift(p,m);
    for(i=0;i<N;i++,p++)
    printf("%3d,",*p);
}


void shift(int *x,int m)
{  
   int i,j,t;
   for (i=0;i<m;i++)
   {
       t=*(x+9);
       for (j=8;j>=0;j--)
       *(x+j+1)=*(x+j);
       *x=t;
  }
}
2010-05-16 21:04
yc2575757
Rank: 7Rank: 7Rank: 7
来 自:北京
等 级:黑侠
威 望:1
帖 子:113
专家分:522
注 册:2010-5-7
收藏
得分:4 
#include <stdio.h>
#define N 10
void fun (int *p, int n, int m)
{
    int i, t, k = 2;
    k = m - 1;
    for (i = 0; i < m; i++)
    {
        t = *(p+k);
        *(p+k) = *(p+n-m+k);
        *(p+n-m+k) = t;
        k--;
    }
}
void main ()
{
    int i, m, a[N];
    printf ("please enter number:");
    for (i = 0; i < N; i++)
    {
        scanf ("%d", &a[i]);
    }
    printf ("please input m(m < 10):");
    scanf ("%d", &m);
    fun (a, N, m);
    for (i = 0; i < N; i++)
    {
        printf ("%d", a[i]);
    }
}
图片附件: 游客没有浏览图片的权限,请 登录注册
2010-05-16 21:29
yjj634041926
Rank: 2
等 级:论坛游民
帖 子:36
专家分:76
注 册:2010-4-15
收藏
得分:0 
回复 8楼 yc2575757
他要的结果应该不是这样吧。。。,,
他应该想要应该想要这样的结果吧。。。
列如:输入“0 1 2 3 4 5 6 7 8 9 ”
假如位移8位  输出:“2345678901”吧。。。
我也不太清楚。。。。
你看呢?
2010-05-16 22:00
赤那
Rank: 3Rank: 3
来 自:广东
等 级:论坛游侠
威 望:1
帖 子:127
专家分:178
注 册:2010-3-1
收藏
得分:4 
#include <stdio.h>
#define N 10
void fun (int *p, int n, int m)
{
    int i, t, k = 2;
    for (i = 0; i < n - m; i++)
    {
        k = i % k;
        t = *p;
        *p = *(p+n-m+k);
        *(p+n-m+k) = t;
    }
}
void main ()
{
    int i, m, a[N];
    printf ("please enter number:");
    for (i = 0; i < N; i++)
    {
        scanf ("%d", &a[i]);
    }
    printf ("please input m(m < 10):");
    scanf ("%d", &m);
    fun (a, N, m);
    for (i = 0; i < N; i++)
    {
        printf ("%d", a[i]);
    }
}
2010-05-16 23:24
快速回复:结果为什么出错
数据加载中...
 
   



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

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