ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

“山无棱,天地合,乃敢与君绝”的数学表示(附C++代码)

2021-12-01 19:31:06  阅读:247  来源: 互联网

标签:23 山无棱 C++ 素数 君绝 83 include 239293 21165


本人发现20017002是“山无棱,天地合,乃敢与君绝”的数学表示。为什么呢?首先,从形上看,1和7是咬合的,然后头尾是回环的。其次,从性质上看,20017002可分解为2x3x3336167,取33361673336167是第239293个素数,239293是第21165个素数,21165分解成3x5x17x83,取83,83是第23个素数,23是第9个素数。得到结果9,长长久久。

另外这里的变换是如果一个数能分解,则取分解后最大的素数,遇到素数,则取素数是第几个素数,如此反复,知道数的大小降为想要的范围。

#include <iostream>
#include <cmath>
using namespace std;
/* run this program using the console pauser or add your own getch, system("pause") or input loop *boo*/

bool IsPrime(int n)   
{
    if(n<2)            
        return false;
    for (int i=2;i*i<=n;i++)  
        {                           
        if(n % i == 0)
            return false;
    }
    return true;
}

int Factorization(int n) {
	for(int i = 2;i < n;++i) {
		if(IsPrime(i) && !IsPrime(n) && n % i == 0) {
			n = n / i;
		}
		if(IsPrime(n)) return n;
	}
}

int main(int argc, char** argv) {
	int ask = 20017002;
	int count = 0;
	while(true) {
		if(IsPrime(ask)) {
		    count = 0;
			for(int i = 2;i <= ask;++i) {
				if(IsPrime(i)) ++count; 
			}
			ask = count;
		}
		else {
			ask = Factorization(ask);
		}
		if(ask <= 10) break;
	} 
	cout << ask << endl;
	
	return 0;
}

  

标签:23,山无棱,C++,素数,君绝,83,include,239293,21165
来源: https://www.cnblogs.com/carmine/p/15630384.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有