博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Greedy:Graveyard Design(POJ 2100)
阅读量:5287 次
发布时间:2019-06-14

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

              

               

  题目大意,给定一个整数,要你找出他的平方和组合

  太简单了。。。。不过一开始我储存平方和想降低时间,后来发现会超内存,直接用时间换空间了,游标卡尺法

  

1 #include 
2 #include
3 #include
4 #define MAX_N 10000001 5 6 using namespace std; 7 typedef long long LL_INT; 8 9 static int store[MAX_N][2];//只储存开始和结尾10 11 void Inivilize(void);12 13 int main(void)14 {15 LL_INT n, sum, tmp;16 int s, t, num;17 18 while (~scanf("%lld", &n))19 {20 sum = num = 0; s = t = 1;21 while (1)22 {23 while ((tmp = (LL_INT)t*(LL_INT)t) <= n && sum < n)24 {25 sum += tmp;26 t++;27 }28 if (sum == n)29 {30 store[num][0] = s; store[num][1] = t;31 num++;32 }33 if (sum < n)34 break;35 sum -= (LL_INT)s*(LL_INT)s; s++;36 }37 printf("%d\n", num);38 for (int i = 0; i < num; i++)39 {40 printf("%d ", store[i][1] - store[i][0]);41 for (int j = store[i][0]; j < store[i][1]; j++)42 printf("%d ", j);43 printf("\n");44 }45 }46 return EXIT_SUCCESS;47 }

  

转载于:https://www.cnblogs.com/Philip-Tell-Truth/p/5155131.html

你可能感兴趣的文章
hdu 1028 Ignatius and the Princess III(母函数入门+模板)
查看>>
Ubuntu下配置安装telnet server
查看>>
Codeforces 235 E Number Challenge
查看>>
ubuntu 常见命令整理
查看>>
EJBCA安装教程+postgresql+wildfly10
查看>>
(五十四)涂鸦的实现和截图的保存
查看>>
配置EditPlus使其可以编译运行java程序
查看>>
java中的占位符\t\n\r\f
查看>>
MySQL通过frm 和 ibd 恢复数据过程
查看>>
SRS源码——Listener
查看>>
Java面向对象抽象类案例分析
查看>>
对SPI、IIC、IIS、UART、CAN、SDIO、GPIO的解释
查看>>
Thymeleaf模板格式化LocalDatetime时间格式
查看>>
庖丁解“学生信息管理系统”
查看>>
Pyltp使用
查看>>
其他ip无法访问Yii的gii,配置ip就可以
查看>>
php做的一个简易爬虫
查看>>
x的x次幂的值为10,求x的近似值
查看>>
jquery获取html元素的绝对位置和相对位置的方法
查看>>
ios中webservice报文的拼接
查看>>