注册 登录
编程论坛 C++教室

小弟我又有问题了

牛仔我很忙 发布于 2008-10-21 22:40, 1233 次点击
#include <iostream.h>
main()
{
    int intarray[5];
    int *pmin;
    int *pt;
    int i;
    for(i=0;i<5;i++)
    {
        cout<<"请输入数字"<<i+1<<endl;
        cin>>intarray[i];
        pmin=&intarray[];
        if(intarray[i]<intarray[i+1])
            *pmin=intarray[i];
        else
            *pmin=intarray[i+1];
    }
    pt=pmin;
    cout<<"最小值为"<<*pt<<endl;
}
要求最小值,用pt遍历数组,pmin始终指向最小的那个数,
小弟指针掌握不是很好,希望大家多指点
12 回复
#2
zhengweitc2008-10-21 22:52
问题蛮多的哈,如果要改变pmin的指向,需要改变其地址值,而不是其指向地址的存储值。
#3
choco10242008-10-21 22:55
输入与查找是分开的吧,哪有一边输入一边比大小的?
#4
choco10242008-10-21 23:05
#include <iostream.h>
main()
{
    int intarray[5];
    int *pmin;
    int *pt;
    int i;
    for(i=0;i<5;i++)
    {
        cout<<"请输入数字"<<i+1<<endl;
        cin>>intarray[i];
    }
    *pmin=&intarray;
    while(i<5)  
   {   
       if(&pmin>intarray[i+1])
            *pmin=intarray[i+1];
       i++
   }
    pt=pmin;
    cout<<"最小值为"<<&pt<<endl;
}
#5
kakaqq2008-10-21 23:06
如楼上·····指针好说。
#6
choco10242008-10-21 23:08
不好意思,有句写错了。
#include <iostream.h>
main()
{
    int intarray[5];
    int *pmin;
    int *pt;
    int i;
    for(i=0;i<5;i++)
    {
        cout<<"请输入数字"<<i+1<<endl;
        cin>>intarray[i];
    }
    pmin=intarray;//在这里,数组名本身就是个地址
    while(i<5)  
   {   
       if(&pmin>intarray[i+1])
            *pmin=intarray[i+1];
       i++
   }
    pt=pmin;
    cout<<"最小值为"<<&pt<<endl;
}
#7
newyj2008-10-22 13:32
楼上  lz 让用*pt来遍历数组 你那个不是画蛇添足吗?
#include <iostream>
using namespace std;

int main()
{
   int intarray[5]={};
   int* pmin=0;
   int* pt=0;
   for (int i=0;i!=5;++i)
     cin>>intarray[i];
   pmin=&intarray[0];
   pt=&intarray[1];
   for (int i=1;i!=5;++i)
     if (*pmin>*pt++)
       *pmin=*--pt;   
   cout<<"最小值为"<<*pmin<<endl;   
   system("pause");   
   getchar();
   return 0;
}
#8
yyj6924714532008-10-26 11:28
7楼怎么把pt++后又pt--呢?  
 for (int i=1;i!=5;++i)
     if (*pmin>*pt++)
       *pmin=*--pt;

 void main()
{
    int intarray[5];
    int *pmin = intarray ;
    int *pt = intarray ;
    int i;
    for(i=0;i<5;i++)
    {
        cout<<"请输入数字"/*<<i+1*/<<endl;
        cin>>intarray[i];
        if ( *pmin > *pt )
            pmin = *&pt ;
        pt ++ ;             
    }
    pt = pmin ;
    cout<<"最小值为"<<*pt<<endl;
}
#9
newyj2008-10-26 11:48
因为不减的话 是下一个数
#10
lyshyhuangli2008-10-26 20:04
pmin = *&pt
8楼的这个是不是有问题啊?
#11
lockhawk2008-10-26 21:17
个人觉的pt很多余啊。明明在遍历的时候就可以找出最小值。
#include <iostream.h>
int main()
{
    int intarray[5];
    int *pmin;
    int i;
    for(i=0;i<5;i++)
    {
        cout<<"请输入数字"<<i+1<<endl;
        cin>>intarray[i];
    }
   pmin=&intarray[0];
   for(int j=0;j<4;j++)  
   {   
       if(*pmin>intarray[j])
          pmin=&intarray[j];
   }
   
    cout<<"最小值为"<<*pmin<<endl;
return 0;
}
#12
pzy12192008-10-26 22:11
for (int i=1;i!=5;++i)
     if (*pmin>*pt++)
       *pmin=*--pt;  
///
    pmin=intarray;
 for(i=0;i<5;i++)  
   {   
       if(&pmin>intarray[i+1])
            *pmin=intarray[i+1];
    }
请问7#,上面两种遍历的方法有什么不同吗?
个人认为是一样的啊
#13
newyj2008-10-26 22:54
是一样的 但是lz 让用pt遍历数组
主要 lz 还是 象 看看 用指针是怎么样运行的
1