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;
    }
    

      

    拥抱明天! 不给自己做枷锁去限制自己。 别让时代的悲哀,成为你人生的悲哀。
  • 相关阅读:
    作业day04
    python开发学习day03 (基本数据类型; 输入输出; 基本运算符)
    作业day03
    作业day02
    python开发学习day02 (编程语言; 解释器 ; 运行方式; IDE; 变量)
    BasePage基础页面的封装
    设定浏览器驱动
    webdriver(chrome无头浏览器)
    webdriervAPI(窗口截图)
    webdriervAPI(常用的js方法)
  • 原文地址:https://www.cnblogs.com/dd2hm/p/6811798.html
Copyright © 2011-2022 走看看