| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 816 人关注过本帖
标题:请教!不明白为什么错了
只看楼主 加入收藏
wenyong
Rank: 1
等 级:新手上路
帖 子:251
专家分:0
注 册:2005-8-9
收藏
 问题点数:0 回复次数:9 
请教!不明白为什么错了
#include "stdio.h"
main()
{int i,n,m,j;
int a[10]={1,2,3,4,5,6,7,8,9,10};
int b[10];
scanf("%d%d",&n,&m);
for(i=0;i<10;i++)
 {
  if (i>=n&&i<=n+m-1)
        {
    b[i]=a[n+m-1];
          m--;
        }
        else
           b[i]=a[i];
 }
 for(j=0;j<=9;j++)
  printf("%d",b[j]);
 
getch();   
}

有何错误?
搜索更多相关主题的帖子: int 何错误 else 
2005-08-10 14:09
changyi5757
Rank: 1
等 级:新手上路
帖 子:35
专家分:0
注 册:2005-7-31
收藏
得分:0 
运行试了,没有发现错误啊
2005-08-10 15:31
wetp
Rank: 1
等 级:新手上路
帖 子:38
专家分:0
注 册:2005-7-18
收藏
得分:0 
当n+m>10的时候数组越界

宠辱不惊,闲看庭前花开花落;去留无意,漫看天外云卷云舒.
2005-08-10 16:07
Knocker
Rank: 8Rank: 8
等 级:贵宾
威 望:47
帖 子:10454
专家分:603
注 册:2004-6-1
收藏
得分:0 
不明白的应该是别人。

九洲方除百尺冰,映秀又遭蛮牛耕。汽笛嘶鸣国旗半,哀伤尽处是重生。     -老K
治国就是治吏。礼义廉耻,国之四维。四维不张,国之不国。   -毛泽东
2005-08-10 16:10
wenyong
Rank: 1
等 级:新手上路
帖 子:251
专家分:0
注 册:2005-8-9
收藏
得分:0 
题目是
设有一数列,包含10个数,已按升序排列。现要求编
一程序,它能够把从指定位置开始的n个数按逆序重新
排列并输出新的完整数列。例如,原数列为1,2,3,4,5,6,7,
8,9,10,若要求把从第4个数开始的5个数按逆序重
新排列,则新数列为1,2,3,8,7,6,5,4,9,10。
结果不正确, 帮忙分析下啊!

2005-08-10 16:22
Knocker
Rank: 8Rank: 8
等 级:贵宾
威 望:47
帖 子:10454
专家分:603
注 册:2004-6-1
收藏
得分:0 
提问题要让别人能明白,一则不会浪费别人的时间和精力,二则你也会更快得到正确回复。

#include "stdio.h"
main()
{
    int i,n,m,j=0,tem ;
    int a[10]=
    {
        1,2,3,4,5,6,7,8,9,10
    }
    ;
   
    scanf("%d%d",&n,&m);
    for(i=0;i<m/2;i++)
    {
        tem=a[i+n-1];
        a[i+n-1]=a[m+n-i-2];
        a[n+m-i-2]=tem ;
     }
    for(j=0;j<=9;j++)
    printf("%3d",a[j]);
   
    getch();
   
}

九洲方除百尺冰,映秀又遭蛮牛耕。汽笛嘶鸣国旗半,哀伤尽处是重生。     -老K
治国就是治吏。礼义廉耻,国之四维。四维不张,国之不国。   -毛泽东
2005-08-10 16:49
wenyong
Rank: 1
等 级:新手上路
帖 子:251
专家分:0
注 册:2005-8-9
收藏
得分:0 
呵呵  谢谢了, 你的思路我明白,但是我的你还没明白类!
我是想用另一个数组存放新排列过的,其他不变化 ,只需在
变化的地方交换下位置!

2005-08-10 16:54
wetp
Rank: 1
等 级:新手上路
帖 子:38
专家分:0
注 册:2005-7-18
收藏
得分:0 

主要有2个问题: 1、从第N个数开始,则是从数组元素的第N-1个开始 2、你判断条件 if (i>=n&&i<=n+m-1) 其实有问题,因为每次你的m值在变小 改后的程序: #include <stdio.h> main() {int i,n,m,j,k; int a[10]={1,2,3,4,5,6,7,8,9,10}; int b[10]; scanf("%d%d",&n,&m); k=m; for(i=0;i<10;i++) { if (i>=n-1&&i<=n+m-2) {

b[i]=a[n+k-2]; k--; } else b[i]=a[i]; } for(j=0;j<=9;j++) printf("%d",b[j]);

getch(); }


宠辱不惊,闲看庭前花开花落;去留无意,漫看天外云卷云舒.
2005-08-10 16:54
wenyong
Rank: 1
等 级:新手上路
帖 子:251
专家分:0
注 册:2005-8-9
收藏
得分:0 
谢谢 楼上分析的对!

2005-08-10 16:59
天堂的叛逆者
Rank: 1
等 级:新手上路
帖 子:25
专家分:0
注 册:2005-8-10
收藏
得分:0 

恩.......昨天看了这道题.......没来得及回答.......恩....今天补上........ 昨天刚开始学turbo c.....有错的地方欢迎大家指正........ [CODE] #include "stdio.h" main() {int i,n,m,j,s; int a[10]; int b[10]; for(s=0;s<10;s++) b[s]=a[s]=s+1; scanf("%d%d",&n,&m); for(i=0;i<m;i++) { b[n-1+i]=a[16-(n+i+m)]; } for(j=0;j<=9;j++) printf("%d",b[j]);

getch(); } [/CODE] 额.....稍微改动了下下......以上代码在turboc2环境下编译通过.........


2005-08-11 07:44
快速回复:请教!不明白为什么错了
数据加载中...
 
   



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

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