main155.cpp
#include
#include
#include
#include
#include
static void output(const long &l){
std::cout<<l<<” “;
}
template
static int reduce(T ar[],int n)
{
std::vector
int len=n;
while(len–)
{
arr.push_back(ar[len]);//将数组复制过去
}
sort(arr.begin(),arr.end());
//std::for_each(arr.begin(),arr.end(),output);//测试排序是否成功
std::cout<<std::endl;
T temp=arr[0];//中间值
T pos=arr[0];
len=n;
ar[0]=temp;//先置ar[0]
int count=1;//ar的下标值
int i=1;//arr的下标值
std::cout<<”ar[0]=”<<ar[0]<<std::endl;
while(i<len+1)//(len)//将arr的值去掉重复后,复制到ar//自己调试一下,看看条件为什么是这个
{
if(temp!=pos)
{
ar[count]=pos;//为了这里ar永远只有一个元素?
std::cout<<”ar[“<<count<<”]=”<<ar[count]<<std::endl;
count++;
temp=pos;//原来是我把数组长度弄错了,导致了上面的问题
}
if(i==len)
break;
pos=arr[i];
i++;
//len–;
}
//count++;
ar[count]=’\0’;//截断数组
std::cout<<std::endl;
//for(int k=0;k<count;k++)
//std::cout<<ar[k]<<” “;
return count;
};
void main165()
{
using std::cout;
using std::endl;
using std::cin;
long ar1[10]={
10,12,9,5,6,
9,5,9,7,150
};
long ar2[8]={
1,5,6,8,
5,6,1,3
};
std::string str[10]={
“add”,”hehe”,”hehe”,”abrot”,”zhen”,
“coco”,”coci”,”cocoy”,”abrot”,”yes”
};
int len=reduce(ar2,8);
cout<<”\nNow is :”<<endl;
for(int i=0;i<len;i++)
cout<<ar2[i]<<” “;
int lenstr=reduce(str,10);
for(int i=0;i<lenstr;i++)
cout<<str[i]<<endl;
cin.get();
}
—————————————————————————————————————————————————— //写的错误或者不好的地方请多多指导,可以在下面留言或者给我发邮件,指出我的错误以及不足,以便我修改,更好的分享给大家,谢谢。 转载请注明出处:https://www.royalchen.com/ author:royalchen Email:royalchen@royalchen.com ———————————————————————————————————————————————————
- 本文作者: royalchen
- 本文链接: http://www.royalchen.com/2016/02/24/cprimerplus第六版课后编程题答案165/
- 版权声明: 本博客所有文章除特别声明外,均采用 MIT 许可协议。转载请注明出处!