zoukankan      html  css  js  c++  java
  • 6.5验证四方定理

    四方定理:所有自然数最多只要4个数的平方和就可以表示,编写一个程序验证四方定理、

    注意: sqrt(n)返回的值是浮点数类型,因此需要int的强制类型转换将其取整。

        最后加一个“no”语句,只是为了保证程序的完整性或防止意外的出现。

    #include<iostream>
    #include<cmath>
    using namespace std;
    
    int mode1(int n) {
    	if((int)sqrt(n) * (int)sqrt(n)==n) {
    		cout<<(int)sqrt(n)<<"*"<<(int)sqrt(n)<<"="<<n;
    		return 1;
    	}
    	else return 0;
    }
    
    int mode2(int n) {
    	for(int x=1;x<sqrt(n);x++)
    	for(int y=x;y<sqrt(n);y++) {
    		if(x*x+y*y==n)
    			{
    			cout<<x<<"*"<<x<<"+"<<y<<"*"<<y<<"="<<n;
    			return 1;	
    			}
    	}
    	return 0;
    }
    
    int mode3(int n) {
    	for(int x=1;x<sqrt(n);x++)
    	for(int y=x;y<sqrt(n);y++)
    	for(int z=y;z<sqrt(n);z++) {
    		if(x*x+y*y+z*z==n)
    			{
    			cout<<x<<"*"<<x<<"+"<<y<<"*"<<y<<"+"<<z<<"*"<<z<<"="<<n;
    			return 1;	
    			}
    	}
    	return 0;
    }
    
    int mode4(int n) {
    	for(int x=1;x<sqrt(n);x++)
    	for(int y=x;y<sqrt(n);y++)
    	for(int z=y;z<sqrt(n);z++)
    	for(int t=z;t<sqrt(n);t++) {
    		if(x*x+y*y+z*z+t*t==n)
    			{
    			cout<<x<<"*"<<x<<"+"<<y<<"*"<<y<<"+"<<z<<"*"<<z<<"+"<<t<<"*"<<t<<"="<<n;
    			return 1;	
    			}
    	}
    	return 0;
    }
    
    int main() {
    	int n;
    	cin>>n;
    	if(mode1(n))	cout<<"yes"<<endl;
    	else if(mode2(n))	cout<<"yes"<<endl;
    	else if(mode3(n))	cout<<"yes"<<endl;
    	else if(mode4(n))	cout<<"yes"<<endl;
    	else cout<<"no";
    	return 0;
    }
    

      

    拥抱明天! 不给自己做枷锁去限制自己。 别让时代的悲哀,成为你人生的悲哀。
  • 相关阅读:
    [Postman]历史(8)
    [Postman]响应(7)
    [Postman]请求(6)
    [Postman]查找替换(5)
    ORA-02050故障诊断一例
    转 js实践篇:例外处理Try{}catch(e){}
    转 PHP
    HTML DOM getElementById() 方法
    地点选择
    9i 和 11 g 区别
  • 原文地址:https://www.cnblogs.com/dd2hm/p/6811798.html
Copyright © 2011-2022 走看看