| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 433 人关注过本帖
标题:谁能帮解释下谢谢
只看楼主 加入收藏
缘中月
Rank: 2
来 自:福建
等 级:论坛游民
帖 子:50
专家分:18
注 册:2010-2-25
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:2 
谁能帮解释下谢谢
程序功能:从键盘输入一个数,插入到已经按降序排列的数组中,要求插入后的数组仍然有序
#include<stdio.h>
void myinsert(int a[],int n,int x)   
{
  int *p,*q;
   for(p=&a[n],q=p-1;*q<x;p--,q--)/*这个循环看不懂谁能解释下谢谢*/
   *p=*q;  
   *p=x;                          /*这里两句也看不懂*/
   return n+1;   
   
}
void myout(int *a,int n)
{
 while(n>0)
     {
      printf("%4d",*a);
      a++;
      n--;
     }
 printf("\n");
}
main()
{
 int a[11]={20,18,16,14,12,10,8,6,4,2},n,k;
 clrscr();
 printf("inserted before:");
 myout(a,10);
 printf("Input data:");
 scanf("%d",&k);
 n=myinsert(a,10,k);
 printf("inserted after:");
 myout(a,n);
}
搜索更多相关主题的帖子: 解释 
2010-06-20 14:25
xiaomanaruto
Rank: 6Rank: 6
等 级:侠之大者
帖 子:79
专家分:443
注 册:2010-4-1
收藏
得分:20 

void myinsert(int a[],int n,int x)   
{
  int *p,*q;
   for(p=&a[n],q=p-1;*q<x;p--,q--)
   *p=*q;  
   *p=x;                          
   return n+1;   
   }
这个函数的解释是,先让一个指针p保存原来数组的组后一个数后面的地址(因为将会有11个数),另一个q指向最后一个数,只要q比插入的那个数小,就是p和q同时往前移一个单位(使两个指针值指向的数变大)同时使小于插入数的每一个数后挫一个位置,直到刚好q指向的值不小于输入的值,使那个值插入现在的位置,完成工作,楼主再仔细看看
2010-06-20 16:40
缘中月
Rank: 2
来 自:福建
等 级:论坛游民
帖 子:50
专家分:18
注 册:2010-2-25
收藏
得分:0 
回复 2楼 xiaomanaruto
谢谢
2010-06-21 12:46
快速回复:谁能帮解释下谢谢
数据加载中...
 
   



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

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