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

成华区微信网站建设在线推广网站的方法

成华区微信网站建设,在线推广网站的方法,越南人一般去哪个网站做贸易,黄骅市中医院题目: 思路: 先在所有树中找到最长的树,从 1 到 这个最长的树的长度 的所有数作为二分查找的值,让每棵树除这个值,表示可以切出几段出来,累加在一起得到s,s表示一共有几段。s与k比较&#xf…

题目: 

思路: 

先在所有树中找到最长的树,从 1 这个最长的树的长度 的所有数作为二分查找的值,让每棵树除这个值,表示可以切出几段出来,累加在一起得到s,s表示一共有几段。s与k比较,如果s==k,表示找到了切出每段的长度,但此时并不能就结束了,也有可能这个长度再长一点,也可以切出我们要的k段。

一开始写的错误代码:

#include<stdio.h>
int cmp(const void *a,const void *b){return *(int *)a-*(int *)b;
}
int main(){long long n,k;//n是指有n根原木,k是指切出k段 scanf("%lld %lld",&n,&k);int i;long long tree[1000005];for(i=0;i<n;i++){scanf("%lld",&tree[i]);}long long sum=0;for(i=0;i<n;i++){sum+=tree[i];}	if(sum/k==0){printf("0");return 0;} qsort(tree,n,sizeof(tree[0]),cmp);long long left=1;long long right=tree[n-1];long long s=0;while(left<=right){s=0;long int mid=(left+right)/2;for(i=0;i<n;i++){s+=tree[i]/mid;}if(s>k){left=mid+1;}else if(s<k){right=mid-1;}else{printf("%lld",mid);break;}}return 0;
}

错就错在了我把s==k的情况单独分出来,然后就break了。

正确的代码:

#include<stdio.h>
int max(int a,int b){if(a>b){return a;}else{return b;}
}
int main(){long long n,k;//n是指有n根原木,k是指切出k段 scanf("%lld %lld",&n,&k);int i;long long tree[1000005];long long max1=0;for(i=0;i<n;i++){scanf("%lld",&tree[i]);max1=max(tree[i],max1);}long long sum=0;for(i=0;i<n;i++){sum+=tree[i];}	if(sum/k==0){printf("0");return 0;} long long left=1;long long right=max1;long long s=0;long long ans;while(left<=right){s=0;long long mid=(left+right)/2;for(i=0;i<n;i++){s+=tree[i]/mid;}if(s>=k){left=mid+1;}else{right=mid-1;}}printf("%lld",left-1);return 0;
}

 我们来重点分析这一段:

        if(s>=k){left=mid+1;}else{right=mid-1;}
printf("%lld",left-1);

其实这种只写两种情况,很好理解,当找到s==k时,left会继续往右走,跨过当前我们找到的这个mid的值, 如果右边还存在可以满足我们要的s==k的情况,就会继续进入s>=k的条件下,然后left又会跨过我们要的mid的值,而如果右边范围不存在s==k,或者s>k也不成立,那么就只会一直进入right=mid-1;此时,left一直没动,right一直在往左移,直到right移到了left左边,循环结束,输出left-1,就是我们当时要的mid值。

有个问题需要注意的是,为什么这个s==k的情况要连在s>k一起写,而不是和s<k,因为当找到s==k的情况时,我们还要再找有没有就是可以切出更长段的k段,所以肯定是要往数值大的方向去找,所以执行的语句是left=mid+1;而不是right=mid-1;

其实也可以拆开写:

        if(s>k){left=mid+1;}else if(s<k){right=mid-1;}else{left=mid+1;}			printf("%lld",left-1);

 

http://www.hrbkazy.com/news/21300.html

相关文章:

  • 临淄区住房和城乡建设局网站常用的网络营销工具有哪些
  • 公司做网站要三千多吗苹果cms永久免费全能建站程序
  • 某网络公司网站源码 蓝色建站企业网站源码新网站怎么快速收录
  • 网站开发能干什么湖南百度seo排名点击软件
  • wordpress5.2.2编辑器中文哈尔滨seo优化培训
  • pc端手机网站 样式没居中企业网络搭建方案
  • 建设工程教育网官方网站百度快照是什么
  • 域名注册新网厦门seo优化外包公司
  • 买房网站排名盐城seo培训
  • 成都家居网站建设万网查询
  • 网站分析报告网络推广优化
  • 网站佣金怎么做凭证做网站需要多少钱 都包括什么
  • 闲鱼怎么做钓鱼网站厦门百度关键词优化
  • 什么网站可以做期货关键词seo优化
  • 上海免费网站建设模板推荐网红推广
  • 公司网站百度搜索的描述怎么做江门关键词排名工具
  • 外贸出口新三样百度seo在哪里
  • 自考大专报名官网入口seo的搜索排名影响因素有哪些
  • 网站只用css做tab切换黄冈网站推广软件
  • 如何将WORDPRESS主题换成英文seo内部优化方式包括
  • 网络服务提供者知道或者应当知道网络福建企业seo推广
  • 公安网站建设方案书厦门seo网站优化
  • 国外电商网站如何建立bt鹦鹉磁力
  • 福州seo推广优化成都网站优化排名推广
  • wordpress 支付宝重庆seo点击工具
  • 做问卷调查赚钱的网站seo技巧是什么
  • 直播课网站怎样做的查排名的网站
  • 网站建设 课程百度购物平台客服电话
  • 百度网站收录链接提交广东seo网站推广代运营
  • 网站建设指南专业seo站长工具