其他分享
首页 > 其他分享> > L1-046 整除光棍 (20 分)

L1-046 整除光棍 (20 分)

作者:互联网

这道题显然要用高精度与低精度的除法,我也是现学现用。
看到网上有很短的巧妙方法,我竟然毫无阅读的欲望。
就是因为编程前期学了太多的奇技淫巧,仅仅为了过题,而没有掌握背后的算法,现在编程能力跟人相差甚远。
踏踏实实写点东西才是关键!

#include<bits/stdc++.h>
using namespace std;
int r=0;
struct bign{
	int d[10005];
	int len;
	bign(){
		memset(d, 0, sizeof(d));
		len = 0;
	}
};
bign divide(bign a, int b){
	bign c;
	c.len = a.len;
	for(int i = a.len-1; i >= 0; i--){
		r = r * 10 + a.d[i];
		c.d[i] = r / b;
		r = r % b;	
	}
	while(c.len-1>=1 && c.d[c.len-1] == 0){
		c.len--;
	}
	return c;
}


int main(){
	int x,L=1;
	cin>>x;
	bign s,u;
	while(1){
		u.len = L;
		for(int i=0;i<L;i++){
			u.d[i] = 1;
		}
		r = 0;  //余数每次开始都要置零 
		s = divide(u, x);
		if(r==0){
			for(int i=s.len-1;i>=0;i--) cout<<s.d[i];
			cout<<" ";
			cout<<u.len<<endl;
			return 0;
		}else L++;
	}
	return 0;
} 

标签:10005,20,int,编程,len,while,bign,L1,046
来源: https://blog.csdn.net/SYaoJun/article/details/97619248