国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

1059. Prime Factors (25)

2019-11-10 19:17:14
字體:
來源:轉載
供稿:網友

1. 原題: https://www.patest.cn/contests/pat-a-PRactise/1059

2. 思路:

題意:將一個數進行分解成質因數,從小到大輸出。思路:題目不難。有多種方法。可以先建立2~根號N的素數表,然后試除。亦或判斷下一個素數的方法處理。我采用的邊除邊判斷,并把質因數保存到map里。這樣繞了遠路了。注意1的特例。

3. 源碼(已AC):

#include<iostream>#include<algorithm>//使用sqrt函數#include<map>using namespace std;int main(void){	//freopen("in.txt", "r", stdin);	int x, i;	cin >> x;	cout << x << '=';	map<int, int> fac;//key是素數,value是指數。	if (x == 1)//1的特例	{		cout << 1 << endl;		return 0;	}	while (x > 1)	{		int flag = 0;//是否可分解的標志位		int limit = (int)sqrt(double(x));		for (i = 2; i <= limit; i++)//循環		{			if (x % i == 0)			{				x /= i;				if (fac.count(i) == 0)					fac[i] = 0;				fac[i]++;				flag = 1;				break;			}		}		if (flag == 0)//0表示已無法再分解。		{			if (fac.count(x) == 0)				fac[x] = 0;			fac[x]++;			break;		}	}	map<int, int>::iterator it;//輸出	for (it = fac.begin(); it != fac.end(); it++)	{		if (it == fac.begin())		{			if (it->second == 1)				cout << it->first;			else				cout << it->first << '^' << it->second;		}		else		{			if (it->second == 1)				cout << '*' << it->first;			else				cout << '*' << it->first << '^' << it->second;		}	}	cout << endl;	return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 香港| 柘荣县| 泗洪县| 湾仔区| 西宁市| 八宿县| 卢龙县| 新宾| 霍邱县| 平舆县| 古浪县| 宜黄县| 如东县| 曲沃县| 浪卡子县| 高碑店市| 新平| 马公市| 会宁县| 保山市| 连州市| 邯郸市| 嘉荫县| 汉川市| 赞皇县| 江都市| 南靖县| 赤城县| 武安市| 民乐县| 兴业县| 内乡县| 东宁县| 巴青县| 平武县| 班玛县| 卢龙县| 延边| 定日县| 佛山市| 桑植县|