| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 735 人关注过本帖
标题:指针变量作函数参数
只看楼主 加入收藏
王一南
Rank: 1
等 级:新手上路
帖 子:29
专家分:0
注 册:2010-11-29
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:6 
指针变量作函数参数
#include <iostream>
using namespace std;
int main ()
{ viod select_sort (int * p,int n);
 int a[10],i;
 cout<<"enter the originl array:"<<endl;
  for (i=0;i<10;i++)
    cin>>a[i];
  cout<<endl;
  select_sort(a,10);
  cout<<"the sorted array:"<<endl;
  for(i=0;i<10;i++)
    cout<<a[i]<<" ";
  cout<<endl;
  return 0;
}
 void select_sort(int*p,int n)
 {int i,j,k,t;
  for(i=0;i<n;i++)
  {k=i;
   for(j=i+1;j<n-1;j++)
     if (*(p+j)<*(p+k)) k=j;
       t=*(p+k);
       *(p+k)=*(p+i);
       *(p+i)=t;
  }
 }
我对这个程序的 void select_sort(int *p,int n)函数中 为什么要k=i,和最后的k=j,  如果不要这两个语句行吗?
搜索更多相关主题的帖子: 变量 指针 函数 参数 
2010-12-15 12:47
xishui777
Rank: 2
等 级:论坛游民
帖 子:53
专家分:94
注 册:2010-8-17
收藏
得分:5 
#include <iostream>
using namespace std;
int main ()
{ void select_sort (int * p,int n);
int a[10],i;
cout<<"enter the originl array:"<<endl;
  for (i=0;i<10;i++)
    cin>>a[i];
  cout<<endl;
  select_sort(a,10);
  cout<<"the sorted array:"<<endl;
  for(i=0;i<10;i++)
    cout<<a[i]<<" ";
  cout<<endl;
  return 0;
}
void select_sort(int*p,int n)
{int i,j,k,t;
  for(i=0;i<n;i++)
  {
   for(j=i+1;j<n-1;j++)
     if (*(p+j)<*(p+i))
      {
       t=*(p+i);
       *(p+i)=*(p+j);
       *(p+j)=t;
      }
  }
}
2010-12-15 12:57
xishui777
Rank: 2
等 级:论坛游民
帖 子:53
专家分:94
注 册:2010-8-17
收藏
得分:0 
可以了
2010-12-15 12:58
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:5 
void select_sort(int*p,int n)
{int i,j,k,t;
  for(i=0;i<n;i++)///////这里应该是 for(i=0;i<n-1;i++)
  {k=i;/////////保存当前的最小值的位置
   for(j=i+1;j<n-1;j++)////////这里应该是 for(j=i+1;j<n;j++)
     if (*(p+j)<*(p+k)) k=j;///如果有比最值小的  就把最小值的位置更新
       t=*(p+k);
       *(p+k)=*(p+i);
       *(p+i)=t;
  }
}
程序代码:
void select_sort(int*p,int n)
{int i,j,k,t;
  for(i=0;i<n-1;i++)
  {k=i;
   for(j=i+1;j<n;j++)
   {
     if (*(p+j)<*(p+k))
         k=j;
   }
   if (i!=k)
   {
       t=*(p+k);
       *(p+k)=*(p+i);
       *(p+i)=t;
   }
  }
}
你的这个选择法写的不太规范  正确的如上

                                         
===========深入<----------------->浅出============
2010-12-15 17:57
王一南
Rank: 1
等 级:新手上路
帖 子:29
专家分:0
注 册:2010-11-29
收藏
得分:0 
回复 4楼 laoyang103
if (i!=k)
   {
       t=*(p+k);
       *(p+k)=*(p+i);
       *(p+i)=t;
   }
  这个必须要吗?  这个程序这样就可以运行啊
2010-12-15 20:49
li_danwang
Rank: 4
来 自:鄂州
等 级:业余侠客
帖 子:112
专家分:203
注 册:2010-11-12
收藏
得分:5 
这个是选择排序法撒.

..

没事来C一下...   
2010-12-16 09:20
kittel
Rank: 2
来 自:武汉
等 级:论坛游民
威 望:1
帖 子:38
专家分:73
注 册:2010-11-19
收藏
得分:5 
回复 楼主 王一南
你这里的k完全可以不要
程序代码:
#include <iostream>
using namespace std;
void select_sort (int* p,int n);//声明在main前
int main ()
{
int a[10],i;
cout<<"enter the originl array:"<<endl;
  for (i=0;i<10;i++)
    cin>>a[i];
  cout<<endl;
  select_sort(a,10);
   return 0;//输出放在函数里,不然你的void函数不会改变原数组值
}
void select_sort(int*p,int n)
{int i,j,t;
  for(i=0;i<n;i++)
  {
   for(j=i+1;j<n;j++)//这里应是j<n
     if (*(p+j)<*(p+i))
     {t=*(p+j);
       *(p+j)=*(p+i);
       *(p+i)=t;}
  }
  cout<<"the sorted array:"<<endl;//输出放在函数里
  for(i=0;i<10;i++)
    cout<<*(p+i)<<" ";
  cout<<endl;
}

2010-12-16 19:26
快速回复:指针变量作函数参数
数据加载中...
 
   



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

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