博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ2100 Graveyard Design(尺取法)
阅读量:4708 次
发布时间:2019-06-10

本文共 2136 字,大约阅读时间需要 7 分钟。

  题目大意:给定一个数n,求出一段连续的正整数的平方和等于n的方案数,并输出这些方案,注意输出格式;

    循环判断条件可以适当剪支,提高效率,(1^2+2^2+..n^2)=n*(n+1)*(2n+1)/6;

    尺取时一定要注意循环终止条件的判断。

    

#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;#define rep(i,a,n) for (int i=a;i
=a;i--)#define in(n) scanf("%d",&(n))#define in2(x1,x2) scanf("%d%d",&(x1),&(x2))#define inll(n) scanf("%I64d",&(n))#define inll2(x1,x2) scanf("%I64d%I64d",&(x1),&(x2))#define inlld(n) scanf("%lld",&(n))#define inlld2(x1,x2) scanf("%lld%lld",&(x1),&(x2))#define inf(n) scanf("%f",&(n))#define inf2(x1,x2) scanf("%f%f",&(x1),&(x2))#define inlf(n) scanf("%lf",&(n))#define inlf2(x1,x2) scanf("%lf%lf",&(x1),&(x2))#define inc(str) scanf("%c",&(str))#define ins(str) scanf("%s",(str))#define out(x) printf("%d\n",(x))#define out2(x1,x2) printf("%d %d\n",(x1),(x2))#define outf(x) printf("%f\n",(x))#define outlf(x) printf("%lf\n",(x))#define outlf2(x1,x2) printf("%lf %lf\n",(x1),(x2));#define outll(x) printf("%I64d\n",(x))#define outlld(x) printf("%lld\n",(x))#define outc(str) printf("%c\n",(str))#define pb push_back#define mp make_pair#define fi first#define se second#define SZ(x) ((int)(x).size())#define mem(X,Y) memset(X,Y,sizeof(X));typedef vector
vec;typedef long long ll;typedef pair
P;const int dx[4]={ 1,0,-1,0},dy[4]={ 0,1,0,-1};const int INF=0x3f3f3f3f;const ll mod=1e9+7;ll powmod(ll a,ll b) {ll res=1;a%=mod;for(;b;b>>=1){ if(b&1)res=res*a%mod;a=a*a%mod;}return res;}const bool AC=true;struct node{ ll num,a,b;};node p[100000];bool cmp(node x,node y){ return x.num>y.num;}int main(){ ll n,s,t,sum,k,cnt;//都设为longlong免得溢出 while(inll(n)!=EOF){ s=t=1;sum=0;k=0; while(true){ while(sum
n) break; //注意循环终止条件 } cnt=k; printf("%I64d\n",cnt);//别忘了这个 sort(p,p+k,cmp); rep(i,0,k){ printf("%I64d ",p[i].num); for(ll j=p[i].a;j<=p[i].b;j++){ printf("%I64d ",j); } printf("\n"); } } return 0;}

 

转载于:https://www.cnblogs.com/akrusher/p/5353125.html

你可能感兴趣的文章
Winform下实现图片切换特效的方法
查看>>
使用 Git 和 Visual Studio Online 进行版本控制
查看>>
AJAX中UPDATEPANEL配合TIMER控件实现局部无刷新
查看>>
html之marquee
查看>>
JS Map对象
查看>>
变量和常量
查看>>
通信项目开发的原理与范例
查看>>
sql数据库(查询)
查看>>
GetMessage 和 PeekMessage 区别
查看>>
DataTable中如何去除重复的项 (获得某个字段中的不重复项)
查看>>
SQL yog过期后教你怎么让他不过期
查看>>
17-MySQL-Ubuntu-数据表的查询-分页(六)
查看>>
Leetcode-441 Arranging Coins
查看>>
SharedPreference.Editor的apply和commit方法异同
查看>>
【转】Caused by: java.lang.NoClassDefFoundError: android.support.v7.gridlayout.R$dimen 异常解决方法...
查看>>
Oracle 数据库字典 sys.col$ 表中关于type#的解释
查看>>
手动写的第一个eChart代码
查看>>
Vue数据绑定隐藏的神坑....
查看>>
邮件欺诈与SPF防御
查看>>
第18月第16天 statusBar
查看>>