| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 701 人关注过本帖
标题:求助 !请问下列程序如果不用类定义能不能做?该怎么改?
取消只看楼主 加入收藏
aiwoleilei
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2010-6-22
结帖率:60%
收藏
已结贴  问题点数:5 回复次数:0 
求助 !请问下列程序如果不用类定义能不能做?该怎么改?
#include <iostream.h>
#include <string.h>

#define MIN 100000
#define MAX 166667

class Number{
private:
int num;
public:
Number();
void getnum();
void sortNums(int nums[]);
int checknum(int i,int temp);
void output(int i);
};

Number::Number(){
num=0;
}
/*
 *函数名:sortNums
 *功能:对nums数组进行冒泡法排序,返回结果
 */
void Number::sortNums(int *nums){
int temp,i,j;
for(i=0;i<6;i++){
for(j=i+1;j<6;j++){
if(nums[i]>nums[j]){
temp=nums[i];
nums[i]=nums[j];
nums[j]=temp;
}
}
}
}
/*
 *函数名:checknum
 *功能:检查乘2,3,4,5,6后得到的积是否由原数的6个数字组成的
 *      mxi=temp*(2,3,4,5,6)
 *返回值:-1 不相同 0 相同
 */
int Number::checknum(int temp,int mxi){
int find,bv,j;
int num1[6],num2[6];
find=0;


  j=0;
while(temp>0){
  bv=temp%10;
    num1[j]=bv;
temp=temp/10;
j=j+1;
}

  j=0;
while(mxi>0){
  bv=mxi%10;
    num2[j]=bv;
mxi=mxi/10;
j=j+1;
}

sortNums(num1);
sortNums(num2);
   
  /*
  按位比较数字是否相等
   */
for(j=0;j<6;j++){
if(num1[j]!=num2[j])
{
find=-1;
break;
}
}

return find;
}

void Number::output(int i){
cout<<"the number is "<<i<<endl;
}

void Number::getnum(){
int i,mxi;

cout<<"begin find number,start "<<MIN<<endl;
for(i=MIN;i<MAX;i++){

mxi=i*2;
if(checknum(i,mxi)<0) continue;
mxi=i*3;
if(checknum(i,mxi)<0) continue;
mxi=i*4;
if(checknum(i,mxi)<0) continue;
mxi=i*5;
if(checknum(i,mxi)<0) continue;
mxi=i*6;
if(checknum(i,mxi)<0) continue;

output(i);
}
cout<<"end find number,end "<<MAX<<endl;
}

int main()
{
int flag=0;
Number number;
number.getnum();
return 0;
}
搜索更多相关主题的帖子: 定义 
2010-06-26 18:46
快速回复:求助 !请问下列程序如果不用类定义能不能做?该怎么改?
数据加载中...
 
   



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

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