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

模拟退火的

题目链接

体验乱调参数而看天意的奇特体验

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<ll,ll> pii;
const int inf=0x3f3f3f3f;
const int N=1e5+10;
const int mod=1e9+7;
//#define int long long
const ll INF=2e9+10;mt19937_64 rd(23333);
uniform_real_distribution<double> drd(0.000001,0.99999);int n,m,c,res;
int a[300];
int b[30][30];
int nx[4]={0,1,0,-1},ny[4]={1,0,-1,0};
int ans[30][30],q;void init(){int pos=1;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){while(a[pos]==0)pos++;a[pos]--;b[i][j]=pos;ans[i][j]=b[i][j];}}for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){for(int k=0;k<4;k++){int xx=i+nx[k];int yy=j+ny[k];if(xx<1||xx>n||yy<1||yy>m)continue;if(b[xx][yy]!=b[i][j])res++;}}}res/=2;q=res;
}int cal(int x,int y){int re=0;for(int k=0;k<4;k++){int xx=x+nx[k];int yy=y+ny[k];if(xx<1||xx>n||yy<1||yy>m)continue;if(b[xx][yy]!=b[x][y])re++;}return re;
}void sa(){for(int t=1e15;t>=1e-15;t*=0.9999){int x1=(rd()%n)+1;int y1=(rd()%m)+1;int x2=(rd()%n)+1;int y2=(rd()%m)+1;if(b[x1][y1]==b[x2][y2])continue;int pre=cal(x1,y1)+cal(x2,y2);swap(b[x1][y1],b[x2][y2]);int nex=cal(x1,y1)+cal(x2,y2);int temp=res+nex-pre;int sub=res-temp;if(sub>0){res=temp;if(res<q){for(int i=1;i<=n;i++)for(int j=1;j<=m;j++)ans[i][j]=b[i][j];q=res;}}else if(exp(sub/t)<1.0*drd(rd))res=temp;elseswap(b[x1][y1],b[x2][y2]);}
}void solve(){cin>>n>>m>>c;for(int i=1;i<=c;i++)cin>>a[i];init();while(clock()/(1.0*CLOCKS_PER_SEC)<=4.89) sa();//cout<<q<<endl;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){if(j>1) cout<<' ';cout<<ans[i][j];}cout<<endl;}
}
signed main(){ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);int t=1;//cin>>t;while(t--){solve();}return 0;
}

http://www.lryc.cn/news/418532.html

相关文章:

  • 为什么有的地方笔记本经常连不上wifi,而手机可以?
  • 组件化开发
  • java学习--文件
  • k8s—Prometheus+Grafana+Altermaneger构建监控平台
  • Dijkstra算法求解最短路径 自写代码
  • C#如何对某个词在字符串中出现的次数进⾏计数(LINQ)
  • Linux篇之OS层内核参数的调优
  • DLMS/COSEM中的信息安全:安全密钥(上)
  • Taro基础知识学习
  • 浮点型在内存中的存储
  • 微信小程序之behaviors
  • java.lang.NoClassDefFoundError: ch/qos/logback/core/util/StatusPrinter2
  • WebRTC ICE配置类型
  • 制造知识普及(八)--企业内部物料编码(IPN)与制造商物料编码(MPN)
  • 大模型学习笔记 - InstructGPT中的微调与对齐
  • Unity近似的Transform实现
  • openvidu私有化部署
  • 基于深度学习的视频伪造检测
  • python机器人编程——开发一个pymatlab工具箱(上)
  • 输入类控件
  • C++20中的模块
  • Selenium与流行框架集成:pytest与Allure报告
  • 日撸Java三百行(day17:链队列)
  • Android摄像头采集选Camera1还是Camera2?
  • 零基础5分钟上手亚马逊云科技AWS核心云开发/云架构 - 创建高可用数据库集群
  • 力扣315.计算右侧小于当前元素的个数
  • websocket,css动画和css-position、display、区别
  • 前端获取视频文件宽高信息和视频时长
  • 【区块链+医疗健康】基于区块链的药品类监管应用管理系统 | FISCO BCOS应用案例
  • MySQL4多表查询 内连接