请问P_BA_sum_delt、deltp_sum以及r,d等变量分别代表什么?懂微网优化的来 5C

function result=fitness(x,k)%判断粒子的适应度,x是一个行向量,适应度就是问题的解,每一个粒子算一次
C_MT=0;
C_GRID=0;
C_BA=0;
P_BA_sum=0;%储能
deltp_sum=0;
P_BA_sum_delt=0;
%储能荷电状态%
BAsocMax=200;%soc:核电状态
P_load=[11.7 12.4 11.7 12.4 11.7 22.4 81.9 122.4 241.3 242.0 241.3 241.3 241.3 240.7 241.3 240.7 241.3 161.0 122.2 121.1 102.9 101.2 23.0 11.1];%负荷
P_pv=[0 0 0 0 0 0 0 0.0391 19.5244 40.0204 50.1010 73.3946 74.3511 76.3489 72.8004 53.1185 4.6258 0 0 0 0 0 0 0];%光伏
G_price=[0 0 0 0 0 0 0 0 0.0931 0.0931 0.0931 0.0931 0.0931 0.0931 0.0931 0.0931 0.0931 0.0931 0.0931 0.0931 0.0931 0 0 0];%有可能是高峰电价

for i=1:72%相当于之前的j
if i C_MT=C_MT+0.04*x(i);%第i个粒子的值
elseif i>24&&i<49
C_GRID= C_GRID+G_price(i-24)*x(i);
else
C_BA=C_BA+8*abs(x(i));%绝对值
end
end

for i=49:72
P_BA_sum=P_BA_sum+(-x(i));
P_BA_sum_delt= P_BA_sum_delt+max(0,P_BA_sum-BAsocMax);
end

if(P_BA_sum_delt<=0)
d=0;
elseif(P_BA_sum_delt>0&&P_BA_sum_delt<=0.001)
d=10;%%%%%迭代次数
elseif(P_BA_sum_delt>0.001&&P_BA_sum_delt<=0.1)
d=20;
elseif(P_BA_sum_delt>0.1&&P_BA_sum_delt<=1.0)
d=100;
else
d=1000;
end

%电功率平衡约束处理
for i=1:24
deltp(i)=abs(P_pv(i)+x(i)+x(i+24)+x(i+48)-P_load(i));
deltp_sum=deltp_sum+deltp(i);
end

if(deltp_sum==0)
r=0.0;
elseif(deltp_sum>0&&deltp_sum<=0.001)
% r=10*sqrt(k);%%%%迭代次数
r=10;
elseif(deltp_sum>0.001&&deltp_sum<=0.1)
r=20;
elseif(deltp_sum>0.1&&deltp_sum<=1.0)
r=100;
else
r=2000;
end
%电功率平衡约束处理

result=C_MT+C_GRID+C_BA+d*P_BA_sum_delt+r*deltp_sum;

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
代码调试成功,但是数据却写入不到文件中去,我用的是VS2017,数据文件也已经放入项目中
想请问一下大家,代码运行没有报错,但是数据写入不到文件中去,请问是什么原因? 这是头文件 ``` _****#ifndef _NS_H #include<stdio.h> #include<math.h> #include<time.h> #define imax 100 #define jmax 100 #define maxit 10000 extern double ma0, a0, u0, v0, p0, t0, tr, tw, tratio, visr, xl, gamma, gascon, pr; extern double vis0; extern double cv, cp, r0, rel, e0; extern double kc0; extern double delt, yl, dx, dy; extern double dtime; extern int iter; extern int convergence; extern int t1, t2; extern double dt; extern double u[imax][jmax], v[imax][jmax], p[imax][jmax], r[imax][jmax], rl[imax][jmax], t[imax][jmax], vis[imax][jmax], ma[imax][jmax]; extern double e[imax][jmax], a[imax][jmax], kc[imax][jmax]; void bc(); void conver(); void dynvis(double tr, double tout, double visr, double visout); void mac(); void mdot(); void output(); void qcx(int i, int j, int icase, double qxout); void qcy(int i, int j, int icase, double qyout); void tauxx(int i, int j, int icase, double txx); void tauxy(int i, int j, int icase, double txy); void tauyy(int i, int j, int icase, double tyy); void thermc(double vis0, double cp, double pr, double kcout); void tstep(); #endif**_** ``` 这是主循环 ``` /* A C program of two-dimensional complete Navier-Stokes equations for the supersonic flow over a flat plate based on MacCormack's explicit time-marching technique. Written by ZhouMingming, January, 2019 Based on John D. Anderson, JR., Chapter 10, In Computational Fluid Dynamics, The Basics with Applications, McGraw-Hill, 2002, 4 */ #include"_NS_H.h" int main() { //初始化流场及各种参数 ma0 = 8; a0 = 340.28; u0 = ma0 * a0; v0 = 0; p0 = 1.01325e5; t0 = 288.16; tr = 288.16; tratio = 2; tw = t0 * tratio; visr = 1.7894e-5; xl = 0.00001; gascon = 287; gamma = 1.4; pr = 0.71; dynvis(tr, t0, visr, vis0); cv = gascon / (gamma - 1); cp = cv * gamma; r0 = p0 / (gascon * t0); e0 = cv * t0; rel = r0 * sqrt(u0*u0 + v0 * v0)*xl / vis0; thermc(vis0, cp, pr, kc0); delt = 5 * xl / sqrt(rel); yl = 5 * delt; dx = xl / (imax - 1); dy = yl / (jmax - 1); FILE *fp4; fp4 = fopen("time.txt", "w"); //主循环 t1 = clock(); for (iter = 0; iter < maxit; iter++) { if (iter == 0) { for (int i = 0; i < imax; i++) { for (int j = 0; j < jmax; j++) { u[i][j] = u0; v[i][j] = v0; p[i][j] = p0; t[i][j] = t0; r[i][j] = r0; rl[i][j] = r0; vis[i][j] = vis0; ma[i][j] = ma0; e[i][j] = e0; kc[i][j] = kc0; a[i][j] = a0; } } } //确定推进时间步长 tstep(); //使用MacCormack time marching algorithm求解 mac(); //确定是否收敛 conver(); if (convergence) { mdot(); output(); } } t2 = clock(); dt = (t2 - t1) / CLOCKS_PER_SEC; fprintf(fp4, "%f", dt); fclose(fp4); } ``` 以下是各个cpp文件 ``` #include"_NS_H.h" void bc() { //定义边界条件 //case1: at (0, 0) u[0][0] = 0; v[0][0] = 0; p[0][0] = p0; t[0][0] = t0; e[0][0] = cv * t[0][0]; r[0][0] = p[0][0] / gascon / t[0][0]; dynvis(tr, t[0][0], visr, vis[0][0]); thermc(vis[0][0], cp, pr, kc[0][0]); a[0][0] = a0; ma[0][0] = 0; //case2: at inflow and upper boundary for (int j = 1; j < jmax; j++) { u[0][j] = u0; v[0][j] = v0; p[0][j] = p0; t[0][j] = t0; e[0][j] = cv * t[0][j]; r[0][j] = p[0][j] / gascon / t[0][j]; dynvis(tr, t[0][j], visr, vis[0][j]); thermc(vis[0][j], cp, pr, kc[0][j]); a[0][j] = a0; ma[0][j] = ma0; } for (int i = 1; i < imax; i++) { u[i][jmax - 1] = u0; v[i][jmax - 1] = v0; p[i][jmax-1] = p0; t[i][jmax-1] = t0; e[i][jmax - 1] = cv * t[i][jmax - 1]; r[i][jmax-1] = p[i][jmax-1] / gascon / t[i][jmax-1]; dynvis(tr, t[i][jmax-1], visr, vis[i][jmax-1]); thermc(vis[i][jmax-1], cp, pr, kc[i][jmax-1]); a[i][jmax-1] = a0; ma[i][jmax-1] = ma0; } //case3: at lower surface boundary for (int i = 1; i < imax; i++) { u[i][0] = 0; v[i][0] = 0; p[i][0] = 2 * p[i][1] - p[i][2]; t[i][0] = tw; e[i][0] = cv * t[i][0]; r[i][0] = p[i][0] / gascon / t[i][0]; dynvis(tr, t[i][0], visr, vis[i][0]); thermc(vis[i][0], cp, pr, kc[i][0]); ``` ``` a[i][0] = sqrt(gamma*gascon*t[i][0]); ma[i][0] = sqrt(u[i][0] * u[i][0] + v[i][0] * v[i][0]) / a[i][0]; } //case4: at outflow boundary for (int j = 1; j < jmax - 1; j++) { u[imax - 1][j] = 2 * u[imax - 2][j] - u[imax - 3][j]; v[imax - 1][j] = 2 * v[imax - 2][j] - v[imax - 3][j]; p[imax - 1][j] = 2 * p[imax - 2][j] - p[imax - 3][j]; t[imax - 1][j] = 2 * t[imax - 2][j] - t[imax - 3][j]; e[imax - 1][j] = cv * t[imax - 1][j]; r[imax - 1][j] = p[imax - 1][j] / gascon / t[imax - 1][j]; dynvis(tr, t[imax - 1][j], visr, vis[imax - 1][j]); thermc(vis[imax - 1][j], cp, pr, kc[imax - 1][j]); a[imax - 1][j] = sqrt(gamma*gascon*t[imax - 1][j]); ma[imax - 1][j] = sqrt(u[imax - 1][j] * u[imax - 1][j] + v[imax - 1][j] * v[imax - 1][j]) / a[imax - 1][j]; } } ``` ``` #include"_NS_H.h" void conver() { FILE *fp1; fp1 = fopen("time.txt", "a"); double rcrit = 0; double dr; for (int i = 0; i < imax; i++) { for (int j = 0; j < jmax; j++) { dr = fabs(r[i][j] - rl[i][j]); if (rcrit < dr) { rcrit = dr; } } } if (rcrit <= 2e-6) { printf("Converence is done!"); convergence = 1; } else { fprintf(fp1, "%d ", iter); fprintf(fp1, "%f ", rcrit); fprintf(fp1, "%f ", dtime); fprintf(fp1, "\n"); fclose(fp1); for (int i = 0; i < imax; i++) { for (int j = 0; j < jmax; j++) { rl[i][j] = r[i][j]; } } convergence = 0; } } ``` ``` #include"_NS_H.h" void dynvis(double tr, double tout, double visr, double visout) { visout = visr * pow(tout / tr, 1.5); visout = visout * (tr + 110) / (tout + 110); } ``` ``` #include"_NS_H.h" double s[5][imax][jmax], f[5][imax][jmax], g[5][imax][jmax]; double sb[5][imax][jmax], sl[5][imax][jmax]; double txx[imax][jmax], txy[imax][jmax], tyy[imax][jmax]; double qx[imax][jmax], qy[imax][jmax]; void mac() { double dsdt; //使用MacCormack's algorithm更新流场变量 for (int i = 0; i < imax; i++) { for (int j = 0; j < jmax; j++) { s[0][i][j] = r[i][j]; s[1][i][j] = r[i][j] * u[i][j]; s[2][i][j] = r[i][j] * v[i][j]; s[3][i][j] = 0; s[4][i][j] = r[i][j] * (e[i][j] + 1 / 2 * (u[i][j] * u[i][j] + v[i][j] * v[i][j])); sl[0][i][j] = r[i][j]; sl[1][i][j] = r[i][j] * u[i][j]; sl[2][i][j] = r[i][j] * v[i][j]; sl[3][i][j] = 0; sl[4][i][j] = r[i][j] * (e[i][j] + 1 / 2 * (u[i][j] * u[i][j] + v[i][j] * v[i][j])); tauxx(i, j, 1, txx[i][j]); tauxy(i, j, 1, txy[i][j]); qcx(i, j, 1, qx[i][j]); f[0][i][j] = s[1][i][j]; f[1][i][j] = s[1][i][j] * s[1][i][j] / s[0][i][j] + p[i][j] - txx[i][j]; f[2][i][j] = s[1][i][j] * s[2][i][j] / s[0][i][j] - txy[i][j]; f[3][i][j] = 0; f[4][i][j] = (s[4][i][j] + p[i][j])*s[1][i][j] / s[0][i][j] + qx[i][j] - s[1][i][j] / s[0][i][j] * txx[i][j] - s[2][i][j] / s[0][i][j] * txy[i][j]; tauyy(i, j, 1, tyy[i][j]); tauxy(i, j, 3, txy[i][j]); qcy(i, j, 1, qy[i][j]); g[0][i][j] = s[2][i][j]; g[1][i][j] = s[1][i][j] * s[2][i][j] / s[0][i][j] - txy[i][j]; g[2][i][j] = s[2][i][j] * s[2][i][j] / s[0][i][j] + p[i][j] - tyy[i][j]; g[3][i][j] = 0; g[4][i][j] = (s[4][i][j] + p[i][j])*s[2][i][j] / s[0][i][j] + qy[i][j] - s[1][i][j] / s[0][i][j] * txy[i][j] - s[2][i][j] / s[0][i][j] * tyy[i][j]; } } //预测步 for (int i = 1; i < imax - 1; i++) { for (int j = 1; j < jmax - 1; j++) { for (int k = 0; k < 5; k++) { dsdt = (f[k][i][j] - f[k][i + 1][j]) / dx + (g[k][i][j] - g[k][i][j + 1]) / dy; sb[k][i][j] = s[k][i][j] + dsdt * dtime; } //decode the variables r[i][j] = sb[0][i][j]; u[i][j] = sb[1][i][j] / sb[0][i][j]; v[i][j] = sb[2][i][j] / sb[0][i][j]; e[i][j] = sb[4][i][j] / sb[0][i][j] - 0.5*v[i][j] * v[i][j]; if (e[i][j] < 0) { e[i][j] = 0; } t[i][j] = e[i][j] / cv; p[i][j] = r[i][j] * gascon*t[i][j]; dynvis(tr, t[i][j], visr, vis[i][j]); thermc(vis[i][j], cp, pr, kc[i][j]); a[i][j] = sqrt(gamma*gascon*t[i][j]); ma[i][j] = v[i][j] / a[i][j]; } } //更新边界条件 bc(); //使用MacCormack's algorithm更新流场变量 for (int i = 0; i < imax; i++) { for (int j = 0; j < jmax; j++) { s[0][i][j] = r[i][j]; s[1][i][j] = r[i][j] * u[i][j]; s[2][i][j] = r[i][j] * v[i][j]; s[3][i][j] = 0; s[4][i][j] = r[i][j] * (e[i][j] + 1 / 2 * (u[i][j] * u[i][j] + v[i][j] * v[i][j])); tauxx(i, j, 2, txx[i][j]); tauxy(i, j, 2, txy[i][j]); qcx(i, j, 2, qx[i][j]); f[0][i][j] = s[1][i][j]; f[1][i][j] = s[1][i][j] * s[1][i][j] / s[0][i][j] + p[i][j] - txx[i][j]; f[2][i][j] = s[1][i][j] * s[2][i][j] / s[0][i][j] - txy[i][j]; f[3][i][j] = 0; f[4][i][j] = (s[4][i][j] + p[i][j])*s[1][i][j] / s[0][i][j] + qx[i][j] - s[1][i][j] / s[0][i][j] * txx[i][j] - s[2][i][j] / s[0][i][j] * txy[i][j]; tauyy(i, j, 2, tyy[i][j]); tauxy(i, j, 4, txy[i][j]); qcy(i, j, 2, qy[i][j]); g[0][i][j] = s[2][i][j]; g[1][i][j] = s[1][i][j] * s[2][i][j] / s[0][i][j] - txy[i][j]; g[2][i][j] = s[2][i][j] * s[2][i][j] / s[0][i][j] + p[i][j] - tyy[i][j]; g[3][i][j] = 0; g[4][i][j] = (s[4][i][j] + p[i][j])*s[2][i][j] / s[0][i][j] + qy[i][j] - s[1][i][j] / s[0][i][j] * txy[i][j] - s[2][i][j] / s[0][i][j] * tyy[i][j]; } } //修正步 for (int i = 1; i < imax - 1; i++) { for (int j = 1; j < jmax - 1; j++) { for (int k = 0; k < 5; k++) { dsdt = (f[i - 1][j][k] - f[i][j][k]) / dx + (g[i][j - 1][k] - g[i][j][k]) / dy; s[i][j][k] = 0.5*(sl[i][j][k] + sb[i][j][k] + dtime * dsdt); } //decode the variables r[i][j] = sb[0][i][j]; u[i][j] = sb[1][i][j] / sb[0][i][j]; v[i][j] = sb[2][i][j] / sb[0][i][j]; e[i][j] = sb[4][i][j] / sb[0][i][j] - 0.5*v[i][j] * v[i][j]; if (e[i][j] < 0) { e[i][j] = 0; } t[i][j] = e[i][j] / cv; p[i][j] = r[i][j] * gascon*t[i][j]; dynvis(tr, t[i][j], visr, vis[i][j]); thermc(vis[i][j], cp, pr, kc[i][j]); a[i][j] = sqrt(gamma*gascon*t[i][j]); ma[i][j] = v[i][j] / a[i][j]; } } //更新边界条件 bc(); } ``` ``` #include"_NS_H.h" void mdot() { //检查质量守恒是否成立 FILE *fp3; fp3 = fopen("dmass.txt", "a"); double massin = 0.0, massout = 0.0; double dmass; for (int j = 0; j < jmax; j++) { massin += r[0][j] * u[0][j]; massout += r[imax - 1][j] * u[imax - 1][j]; } dmass = fabs(massout - massin) / massin * 100; if (dmass > 1.0) { fprintf(fp3, "%f ", dmass); fprintf(fp3, "\n"); fclose(fp3); } } ``` ``` #include"_NS_H.h" void output() { double x[imax], y[jmax]; FILE *fp2; fp2 = fopen("output.txt", "a"); for (int i = 0; i < imax; i++) { x[i] = dx * i; } for (int j = 0; j < jmax; j++) { y[j] = dy * j; } for (int i = 0; i < imax; i++) { for (int j = 0; j < jmax; j++) { fprintf(fp2, "%f ", x[i]); fprintf(fp2, "%f ", y[i]); fprintf(fp2, "%f ", u[i][j] / u0); fprintf(fp2, "%f ", v[i][j]); fprintf(fp2, "%f ", p[i][j] / p0); fprintf(fp2, "%f ", t[i][j] / t0); fprintf(fp2, "%f ", r[i][j] / r0); fprintf(fp2, "%f ", a[i][j]); fprintf(fp2, "%f ", ma[i][j]); fprintf(fp2, "\n"); } } fclose(fp2); } ``` ``` #include"_NS_H.h" void qcx(int i, int j, int icase, double qxout) { double dtdx; switch (icase) { //向前差分时 case 1: if (i == 0) { dtdx = (t[1][j] - t[0][j]) / dx; } else { dtdx = (t[i][j] - t[i - 1][j]) / dx; } break; //向后差分时 case 2: if (i == imax - 1) { dtdx = (t[imax - 1][j] - t[imax - 2][j]) / dx; } else { dtdx = (t[i + 1][j] - t[i][j]) / dx; } break; } qxout = -1 * kc[i][j] * dtdx; } ``` ``` #include"_NS_H.h" void qcy(int i, int j, int icase, double qyout) { double dtdy; switch (icase) { //向前差分时 case 1: if (j == 0) { dtdy = (t[i][1] - t[i][0]) / dy; } else { dtdy = (t[i][j] - t[i][j - 1]) / dy; } break; //向后差分时 case 2: if (j == jmax - 1) { dtdy = (t[i][jmax-1] - t[i][jmax-2]) / dy; } else { dtdy = (t[i][j+1] - t[i][j]) / dy; } break; } qyout = -1 * kc[i][j] * dtdy; } ``` ``` #include"_NS_H.h" void tauxx(int i, int j, int icase, double txx) { double dudx, dvdy; switch (icase) { //dF/dX为向前差分 case 1: if (j == 0) { dvdy = (v[i][1] - v[i][0]) / dy; } else if (j == jmax - 1) { dvdy = (v[i][jmax - 1] - v[i][jmax - 2]) / dy; } else { dvdy = (v[i][j + 1] - v[i][j - 1]) / 2 / dy; } if (i == 0) { dudx = (u[1][j] - u[0][j]) / dx; } else { dudx = (u[i][j] - u[i - 1][j]) / dx; } break; //dF/dX为向后差分 case 2: if (j == 0) { dvdy = (v[i][1] - v[i][0]) / dy; } else if (j == jmax - 1) { dvdy = (v[i][jmax - 1] - v[i][jmax - 2]) / dy; } else { dvdy = (v[i][j + 1] - v[i][j - 1]) / 2 / dy; } if (i == imax-1) { dudx = (u[imax - 1][j] - u[imax - 2][j]) / dx; } else { dudx = (u[i + 1][j] - u[i][j]) / dx; } break; } txx = vis[i][j] * (4 / 3 * dudx - 2 / 3 * dvdy); } ``` ``` #include"_NS_H.h" void tauxy(int i, int j, int icase, double txy) { double dudy, dvdx; switch (icase) { //dF/dX为向前差分 case 1: if (j == 0) { dudy = (u[i][1] - u[i][0]) / dy; } else if (j == jmax - 1) { dudy = (u[i][jmax - 1] - u[i][jmax - 2]) / dy; } else { dudy = (u[i][j + 1] - u[i][j - 1]) / 2 / dy; } if (i == 0) { dvdx = (v[1][j] - v[0][j]) / dx; } else { dvdx = (v[i][j] - v[i - 1][j]) / dx; } break; //dF/dX为向后差分 case 2: if (j == 0) { dudy = (u[i][1] - u[i][0]) / dy; } else if (j == jmax - 1) { dudy = (u[i][jmax - 1] - u[i][jmax - 2]) / dy; } else { dudy = (u[i][j + 1] - u[i][j - 1]) / 2 / dy; } if (i == imax - 1) { dvdx = (v[imax - 1][j] - v[imax - 2][j]) / dx; } else { dvdx = (v[i + 1][j] - v[i][j]) / dx; } break; //dG/dy为向前差分 case 3: if (i == 0) { dvdx = (v[1][j] - v[0][j]) / dx; } else if (i == imax - 1) { dvdx = (v[imax - 1][j] - v[imax - 2][j]) / dx; } else { dvdx = (v[i + 1][j] - v[i - 1][j]) / 2 / dx; } if (j == 0) { dudy = (u[i][1] - u[i][0]) / dy; } else { dudy = (u[i][j] - u[i][j - 1]) / dy; } break; //dG/dy为向后差分 case 4: if (i == 0) { dvdx = (v[1][j] - v[0][j]) / dx; } else if (i == imax - 1) { dvdx = (v[imax - 1][j] - v[imax - 2][j]) / dx; } else { dvdx = (v[i + 1][j] - v[i - 1][j]) / 2 / dx; } if (j == jmax-1) { dudy = (u[i][jmax - 1] - u[i][jmax - 2]) / dy; } else { dudy = (u[i][j + 1] - u[i][j]) / dy; } break; } txy = vis[i][j] * (dudy + dvdx); } ``` ``` #include"_NS_H.h" void tauyy(int i, int j, int icase, double tyy) { double dudx, dvdy; switch (icase) { //dG/dy为向前差分 case 1: if (i == 0) { dudx = (u[1][j] - u[0][j]) / dx; } else if (i == imax-1) { dudx = (u[imax - 1][j] - u[imax - 2][j]) / dx; } else { dudx = (u[i + 1][j] - u[i - 1][j]) / 2 / dx; } if (j == 0) { dvdy = (v[i][1] - v[i][0]) / dy; } else { dvdy = (v[i][j] - v[i][j - 1]) / dy; } break; //dG/dy为向后差分 case 2: if (i == 0) { dudx = (u[1][j] - u[0][j]) / dx; } else if (i == imax - 1) { dudx = (u[imax - 1][j] - u[imax - 2][j]) / dx; } else { dudx = (u[i + 1][j] - u[i - 1][j]) / 2 / dx; } if (j == jmax - 1) { dvdy = (v[i][jmax - 1] - v[i][jmax - 2]) / dy; } else { dvdy = (v[i][j + 1] - v[i][j]) / dy; } break; } tyy = vis[i][j] * (4 / 3 * dvdy - 2 / 3 * dudx); } ``` ``` #include"_NS_H.h" void thermc(double vis0, double cp, double pr, double kcout) { kcout = vis0 * cp / pr; } ``` ``` #include"_NS_H.h" double vv[imax][jmax], dtt[imax][jmax]; double rex[imax][jmax], rey[imax][jmax]; void tstep() { double vvmax = 0; double dt1, dt2, dt3; double dtmin = 1; double tf = 0.5; double rexmax = 0, reymax = 0; for (int i = 1; i < imax - 1; i++) { for (int j = 1; j < jmax - 1; j++) { vv[i][j] = 4 / 3*gamma*vis[i][j] * vis[i][j] / pr / r[i][j]; rex[i][j] = r[i][j] * u[i][j] * dx / vis[i][j]; rey[i][j] = r[i][j] * v[i][j] * dy / vis[i][j]; if (rexmax < rex[i][j]) { rexmax = rex[i][j]; } if (reymax < rey[i][j]) { reymax = rey[i][j]; } if (vvmax < vv[i][j]) { vvmax = vv[i][j]; } } } for (int i = 1; i < imax - 1; i++) { for (int j = 1; j < jmax - 1; j++) { dt1 = sqrt(u[i][j]) / dx + sqrt(v[i][j]) / dy; dt2 = dt1 + a[i][j] * sqrt(1 / (dx*dx) + 1 / (dy*dy)); dt3 = dt2 + 2 * vvmax*(1 / dx / dx + 1 / dy / dy); dtt[i][j] = 1 / dt3; if (dtmin > dtt[i][j]) { dtmin = dtt[i][j]; } } } dtime = tf * dtmin; } ```
flash 图片放大,放大五次就不放大,那个大于5的地方怎么写
var dogInitx:Number = image_mc.x + image_mc.width/2; var dogInity:Number = image_mc.y + image_mc.height/2; var cs=0; //添加滚轮侦听 stage.addEventListener(MouseEvent.MOUSE_WHEEL,changeDogScale); function changeDogScale(e:MouseEvent):void { var delt:int = int(e.delta); image_mc.scaleX =image_mc.scaleY += delt/100; //判断尺寸变负时赋予它最小值 if(image_mc.scaleX < 0) { image_mc.scaleX = image_mc.scaleY = 0.1; return; } cs++; if(cs>=5) { return; } //记录当前中心位置 }
Android调试- 删除TextView,Button和Layout引发崩溃
当我点击按钮来删除一个TextView ,Button 和 LinearLayout.时,程序崩溃。下面是logcat输出,当我想在118行删除View时就崩溃了。 tasklayout.removeView(taskbutton); 04-15 14:35:58.222: E/AndroidRuntime(632): java.lang.NullPointerException 04-15 14:35:58.222: E/AndroidRuntime(632): at com.com.com.addtask.deltask(addtask.java:118) 04-15 14:35:58.222: E/AndroidRuntime(632): at com.com.com.addtask$2.onClick(addtask.java:65) 04-15 14:35:58.222: E/AndroidRuntime(632): at android.view.View.performClick(View.java:3511) 04-15 14:35:58.222: E/AndroidRuntime(632): at android.view.View$PerformClick.run(View.java:14105) 04-15 14:35:58.222: E/AndroidRuntime(632): at android.os.Handler.handleCallback(Handler.java:605) onClickListner 和 deltask void Button delt = (Button) findViewById(R.id.btndelete1); delt.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { deltask(v); } }); public void deltask(View v) { SharedPreferences datatask; datatask = getSharedPreferences(filename, 0); int tnum = datatask.getInt("tasknumber", 1); int layoutnum = 1000 + tnum; int textviewnum = 1100 + tnum; int buttonviewnum = 1200 + tnum; LinearLayout layout = (LinearLayout) findViewById(R.id.taskll); LinearLayout tasklayout = (LinearLayout) findViewById(layoutnum); TextView tasktv = (TextView) findViewById(textviewnum); Button taskbutton = (Button) findViewById(buttonviewnum); tasklayout.removeView(taskbutton); tasklayout.removeView(tasktv); layout.removeView(tasklayout); }
jdbc无法执行删除操作
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; import java.util.Scanner; public class delt { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub //装载驱动 Connection con=null; PreparedStatement pre=null; Scanner input=new Scanner(System.in); System.out.print("输入要删除的姓名:"); String name=input.next(); try { Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); //得到数据库的连接对象 String url="jdbc:sqlserver://127.0.0.1:1433;DatabaseName=us"; con=DriverManager.getConnection(url,"sa","123456"); //编写SQL语句 String sql="delete name from st where name=?"; //建立一个预处理对象 pre=con.prepareStatement(sql); pre.setString(1,name); System.out.println("11"); int i=pre.executeUpdate(); //con.commit(); System.out.println("22"); if(i>0) System.out.println("删除成功"); else System.out.println("操作未成功"); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); }finally{ try { con.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } } ``` ``` 输入要删除的姓名:王二 11 com.microsoft.sqlserver.jdbc.SQLServerException: 对象名 'name' 无效。 at com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDatabaseError(Unknown Source) at com.microsoft.sqlserver.jdbc.IOBuffer.processPackets(Unknown Source) at com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement.getPrepExecResponse(Unknown Source) at com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement.doExecutePreparedStatement(Unknown Source) at com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement$PreparedStatementExecutionRequest.executeStatement(Unknown Source) at com.microsoft.sqlserver.jdbc.CancelableRequest.execute(Unknown Source) at com.microsoft.sqlserver.jdbc.SQLServerConnection.executeRequest(Unknown Source) at com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement.executeUpdate(Unknown Source) at delt.main(delt.java:33)
C语言实现PE移动重定位表
修改了一个dll的ImageBase,与原有ImageBase的差值为delt,PE移动重定位表时直接将每个块的VirtualAddress修改为VirtualAddress+delt,然后循环每个块重复这个过程,知道最后一个块的VirtualAddress为0停止,运行时为什么错了。求大神的C语言版的移动重定位表代码
poj 1328 Running time 错误 求助
#include<iostream> using namespace std; #include<math.h> void sort_com(int dot[][2],int num)//对小岛根据x坐标排序 { int judge=1; while(judge) { judge=0; for(int i=0;i<num-1;i++) { if(dot[i][0]>dot[i+1][0]) { int temp1=dot[i][0]; int temp2=dot[i][1]; dot[i][0]=dot[i+1][0]; dot[i][1]=dot[i+1][1]; dot[i+1][0]=temp1; dot[i+1][1]=temp2; judge=1; } } } } float range(int y,int d) //求一个岛在海岸线上所允许的圆心值范围,-1表示不存在 { if(d*d-y*y<0) return -1; return sqrt((float)(d*d-y*y)); } int select_dot(int dot[][2],int d,int num)//寻找区间最少数 { int b[100][2]; for(int i=0;i<num;i++) { float delt=range(dot[i][1],d); if(delt<0) return -1; b[i][0]=dot[i][0]-delt; b[i][1]=dot[i][0]+delt; } int center=b[0][1]; int result=1; for(int i=0;i<num;i++) { if(b[i][0]>center) { center=b[i][1]; result++;//需要增加一个雷达 } } return result; } int main(void) { int dot[100][2],d,num,times=0;//times表示有几个case int answer[100]; for(int i=0;i<100;i++)//初始化 for(int j=0;j<2;j++) dot[i][j]=0; cin>>num>>d; while(d!=0||num!=0) { for(int i=0;i<num;i++) cin>>dot[i][0]>>dot[i][1]; sort_com(dot,num); answer[times]=select_dot(dot,d,num); times++; cin>>num>>d; } for(int i=1;i<=times;i++) cout<<"Case "<<i<<": "<<answer[i-1]<<endl;//输出 return 0; } poj 显示Running time 的错误过不了,求助
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小型人工智障。 知识可以运用在不同地方,不一定非是天气预报。
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
英特尔不为人知的 B 面
从 PC 时代至今,众人只知在 CPU、GPU、XPU、制程、工艺等战场中,英特尔在与同行硬件芯片制造商们的竞争中杀出重围,且在不断的成长进化中,成为全球知名的半导体公司。殊不知,在「刚硬」的背后,英特尔「柔性」的软件早已经做到了全方位的支持与支撑,并持续发挥独特的生态价值,推动产业合作共赢。 而对于这一不知人知的 B 面,很多人将其称之为英特尔隐形的翅膀,虽低调,但是影响力却不容小觑。 那么,在...
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看...
白话阿里巴巴Java开发手册高级篇
不久前,阿里巴巴发布了《阿里巴巴Java开发手册》,总结了阿里巴巴内部实际项目开发过程中开发人员应该遵守的研发流程规范,这些流程规范在一定程度上能够保证最终的项目交付质量,通过在时间中总结模式,并推广给广大开发人员,来避免研发人员在实践中容易犯的错误,确保最终在大规模协作的项目中达成既定目标。 无独有偶,笔者去年在公司里负责升级和制定研发流程、设计模板、设计标准、代码标准等规范,并在实际工作中进行...
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
【图解经典算法题】如何用一行代码解决约瑟夫环问题
约瑟夫环问题算是很经典的题了,估计大家都听说过,然后我就在一次笔试中遇到了,下面我就用 3 种方法来详细讲解一下这道题,最后一种方法学了之后保证让你可以让你装逼。 问题描述:编号为 1-N 的 N 个士兵围坐在一起形成一个圆圈,从编号为 1 的士兵开始依次报数(1,2,3…这样依次报),数到 m 的 士兵会被杀死出列,之后的士兵再从 1 开始报数。直到最后剩下一士兵,求这个士兵的编号。 1、方...
吐血推荐珍藏的Visual Studio Code插件
作为一名Java工程师,由于工作需要,最近一个月一直在写NodeJS,这种经历可以说是一部辛酸史了。好在有神器Visual Studio Code陪伴,让我的这段经历没有更加困难。眼看这段经历要告一段落了,今天就来给大家分享一下我常用的一些VSC的插件。 VSC的插件安装方法很简单,只需要点击左侧最下方的插件栏选项,然后就可以搜索你想要的插件了。 下面我们进入正题 Material Theme ...
如何防止抄袭PCB电路板
目录 1、抄板是什么 2、抄板是否属于侵权 3、如何防止抄板 1、抄板是什么 抄板也叫克隆或仿制,是对设计出来的PCB板进行反向技术研究;目前全新的定义:从狭义上来说,抄板仅指对电子产品电路板PCB文件的提取还原和利用文件进行电路板克隆的过程;从广义上来说,抄板不仅包括对电路板文件提取、电路板克隆、电路板仿制等技术过程,而且包括对电路板文件进行修改(即改板)、对电子产品外形模具进行三维...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
Java世界最常用的工具类库
Apache Commons Apache Commons有很多子项目 Google Guava 参考博客
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下...
为什么要学数据结构?
一、前言 在可视化化程序设计的今天,借助于集成开发环境可以很快地生成程序,程序设计不再是计算机专业人员的专利。很多人认为,只要掌握几种开发工具就可以成为编程高手,其实,这是一种误解。要想成为一个专业的开发人员,至少需要以下三个条件: 1) 能够熟练地选择和设计各种数据结构和算法 2) 至少要能够熟练地掌握一门程序设计语言 3) 熟知所涉及的相关应用领域的知识 其中,后两个条件比较容易实现,而第一个...
金山办公上市,雷军心愿了却!
作者 | 胡巍巍 出品 | CSDN(ID:CSDNnews) 11月17日,大周末的,雷军微博发了个重磅消息: “明天将是里程碑式的一天,金山办公终于成功在科创板挂牌上市了! 从1988年金山创办到今天,WPS走了整整31年。 从1999年以金山办公为主体准备上市算起,这一天,我们等了20年。 WPS和金山的历程,这是一个坚持梦想并最终取得胜利的励志故事。期待大家的祝福!”...
8年经验面试官详解 Java 面试秘诀
作者 |胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。 Java程序员准备和投递简历的实...
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车?某胡同口的煎饼摊一年能卖出多少个煎饼?深圳有多少个产品经理?一辆公交车里能装下多少个乒乓球?一个正常成年人有多少根头发?这类估算问题,被称为费米问题,是以科学家费米命名的。为什么面试会问这种问题呢?这类问题能把两类人清楚地区分出来。一类是具有文科思维的人,擅长赞叹和模糊想象,它主要依靠的是人的第一反应和直觉,比如小孩...
17张图带你解析红黑树的原理!保证你能看懂!
二叉查找树 由于红黑树本质上就是一棵二叉查找树,所以在了解红黑树之前,咱们先来看下二叉查找树。 二叉查找树(Binary Search Tree),也称有序二叉树(ordered binary tree),排序二叉树(sorted binary tree),是指一棵空树或者具有下列性质的二叉树: 若任意结点的左子树不空,则左子树上所有结点的值均小于它的根结点的值; 若任意结点的...
so easy! 10行代码写个"狗屁不通"文章生成器
前几天,GitHub 有个开源项目特别火,只要输入标题就可以生成一篇长长的文章。 背后实现代码一定很复杂吧,里面一定有很多高深莫测的机器学习等复杂算法 不过,当我看了源代码之后 这程序不到50行 尽管我有多年的Python经验,但我竟然一时也没有看懂 当然啦,原作者也说了,这个代码也是在无聊中诞生的,平时撸码是不写中文变量名的, 中文...
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的回答,对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalking,作者吴晟、刘浩杨 等等 仓库地址: apache/skywalking 更...
MySQL数据库总结
一、数据库简介 数据库(Database,DB)是按照数据结构来组织,存储和管理数据的仓库。 典型特征:数据的结构化、数据间的共享、减少数据的冗余度,数据的独立性。 关系型数据库:使用关系模型把数据组织到数据表(table)中。现实世界可以用数据来描述。 主流的关系型数据库产品:Oracle(Oracle)、DB2(IBM)、SQL Server(MS)、MySQL(Oracle)。 数据表:数...
记一次腾讯面试:进程之间究竟有哪些通信方式?如何通信? ---- 告别死记硬背
有一次面试的时候,被问到进程之间有哪些通信方式,不过由于之前没深入思考且整理过,说的并不好。想必大家也都知道进程有哪些通信方式,可是我猜很多人都是靠着”背“来记忆的,所以今天的这篇文章,讲给大家详细着讲解他们是如何通信的,让大家尽量能够理解他们之间的区别、优缺点等,这样的话,以后面试官让你举例子,你也能够顺手拈来。 1、管道 我们来看一条 Linux 的语句 netstat -tulnp | gr...
相关热词 c# 二进制截断字符串 c#实现窗体设计器 c#检测是否为微信 c# plc s1200 c#里氏转换原则 c# 主界面 c# do loop c#存为组套 模板 c# 停掉协程 c# rgb 读取图片
立即提问