当前位置: 首页 > wzjs >正文

大兴做网站公司wordpress 购物模板

大兴做网站公司,wordpress 购物模板,微商城网站建设教程,科技公司网站设计方案做题思路 数列分段 Section IIhttps://www.luogu.com.cn/problem/P1182正如题目所说,我们需要得到一个最小的最大段的值,可能有人将注意力放在分段上,事实上,我们更多的应该关注结果。这是一道二分答案的题,你可以先确…

做题思路

数列分段 Section IIhttps://www.luogu.com.cn/problem/P1182正如题目所说,我们需要得到一个最小的最大段的值,可能有人将注意力放在分段上,事实上,我们更多的应该关注结果。这是一道二分答案的题,你可以先确认某次分段后的可能的最大段的值q,然后尽量往最大段的值方向去分段,这样,在保证了分段后的最大段的值小于等于q,再看所分的段数,如果大于限定的段数,说明不可能最大段的值是q。因为在保证所分段的值不超过q的情况下,无法减少段数使其达到要求,这时应该往大于q的范围上去找。如果小于等于限定的段数,说明可能还有更小的q。因为段数小于要求,可以将某段拆成多段来增大段数,这时可能有更小的q符合要求。而这时为了更快的找到q的值,我们可以使用二分查找的方式去找。对于n个数,最小的q就是每个一段分出n段时,n个数中的最大值,最大的q就是只分出1段时,n个数的和。

#include<stdio.h>
#include<stdlib.h>
int check(int max,int *data,int num,int limit_count){int current_sum=0,count=0;for(int i=0;i<num;i++){if(data[i]>max)return 0;if(current_sum+data[i]>max){count++;current_sum=data[i];}else current_sum+=data[i];}count++;return count<=limit_count;
}
int main() {int N, M, max = 0, sum = 0;scanf("%d %d", &N, &M);int *data = (int*)malloc(sizeof(int) * N);for (int i = 0; i < N; i++) {scanf("%d", &data[i]);sum += data[i];if (data[i] > max)max = data[i];}int left=max,right=sum;while(left<right){int mid=(left+right)/2;if(check(mid,data,N,M))right=mid;else left=mid+1;}printf("%d",left);free(data);return 0;
}

书的复制https://www.luogu.com.cn/problem/P1281 这道题的思路和上面的题一模一样,但要注意输出时的条件:行的起始编号应该从小到大排列,如果有多解,则尽可能让前面的人少抄写。

#include<stdio.h>
#include<stdlib.h>
int check(int max,int *data,int num,int limit_count){int current_sum=0,count=0;for(int i=0;i<num;i++){if(data[i]>max)return 0;if(current_sum+data[i]>max){count++;current_sum=data[i];}else current_sum+=data[i];}count++;return count<=limit_count;
}
int main() {int N, M, max = 0, sum = 0;scanf("%d %d", &N, &M);int *data = (int*)malloc(sizeof(int) * N);for (int i = 0; i < N; i++) {scanf("%d", &data[i]);sum += data[i];if (data[i] > max)max = data[i];}int left=max,right=sum;while(left<right){int mid=(left+right)/2;if(check(mid,data,N,M))right=mid;else left=mid+1;}int result[M][2],current_sum=0,count=0;result[0][1]=N,result[M-1][0]=1;for(int i=N;i>0;i--){if(current_sum+data[i-1]>left){result[count++][0]=i+1;result[count][1]=i;current_sum=data[i-1];}else current_sum+=data[i-1];}for(int i=M-1;i>=0;i--){printf("%d %d\n",result[i][0],result[i][1]);}free(data);return 0;
}
http://www.dtcms.com/wzjs/833548.html

相关文章:

  • 影视网站建设需要学什么注册公司流程图片
  • 做视频网站要多少钱抖音代运营合同模板免费完整版
  • 内江做网站的公司营销型网站有哪些
  • 动易 网站顶部导航 sitefactory青锐成长计划网站开发人员
  • 某些网站域名解析错误深圳logo设计公司排名
  • 自网站EXCel数据导入怎么做杭州手机网站开发
  • 淘宝网站建设违规吗要建一个网站怎么做
  • 青岛网站建设 百度做前后端网站教程
  • 个人网站论文摘要北京网站建设 网站制作
  • 个人网站策划书范文怎么搭建个人网站
  • 手表网站欧米茄价格wordpress 升级失败
  • 郑州 公司网站制作网站建设权利义务
  • 免费网站在线观看人数在哪直播社群营销的十大案例
  • 网站建设流量从哪里来电脑上字体怎么到wordpress
  • 青白江区网站开发招聘中铁三局招聘要求
  • 织梦网站模版怎么用wordpress侧栏菜单加上序号
  • 宝和网站建设网站内页权重怎么查
  • 网站建设评分做淘客网站 备案
  • 汕头网站设计浩森宇特wordpress简历
  • 网页设计师必须知道的网站wordpress oss压缩
  • 品牌网站建设熊掌号四川省建设厅官方网站扣分记录
  • 杭州做网站博客浙江电商网站建设销售
  • 网站分几个阶段建设如何攻克网站
  • 响应式网站设计规则h5网站建设报价多少钱
  • 南京市建设工程档案馆网站怎么自己在百度上做网站
  • 手机网站域名如何解析wordpress用php版本号
  • 湖南茶叶网站建设杭州学校网站开发
  • 网站官网新女权时代的到来wordpress
  • 好网站分享网站推广方式大全
  • 卫浴网站模板网站开发公司营业范围