立体统计图表绘制方法(凸显式环图)

立体统计图表绘制方法(凸显式环图)
记得我学统计学的时候,那些统计图表大都是平面的框框图,很呆板,就只是表现出统计的意义就好了。在网络科技发展进步的当下,原来一些传统的统计图表都有了进一步的创新。在统计图的形式和艺术表现力的美工方面都有了长足的进步。以前企业的PPT都依赖微软的各应用软件来制作图表,现时企业的PPT展示的图表应用不再满足于Excle,Word等的图表绘制方法,进而使用一些第三方应用软件来制作新颖漂亮的图表。由此而有许多图表制作的应用软件面市。这些图表很吸引眼球,我对此也很感兴趣,故试着写了一些各种式样图表的绘制方法,供有同好的同行参考和评论。如果自己在做PPT时加入自己设计制作的图表,我相信这会使人有耳目一新的感觉,还会得到大家的青睐。这会使你感到很有成就感。我就是这样做的。

新样式的统计图有复合式,堆叠式,展开式等等,不一而足。在美工艺术方面有许多独到新颖的样式,给人一个赏心悦目的感受。

今在此提供一种新颖漂亮的立体形式的统计图的绘制方法供参考。
分离式的立体图形绘制较难,再介绍一种凸显形式的立体环图。
凸显形式的立体图就是绘制立体的图块,以立体图块的体积来表现统计意义的占比分析,凸显主要的样本值。
本方法采用C语言的最基本功能:绘图功能画线,画圆,画矩形。
代码中有详细的注释,通俗易懂,一看就会。


下面是绘制艺术统计图表的代码:
//变量: 可设置成全局变量或私有变量
Canvas cs ;     //画布,绘制图表载体
float pi=3.1415926535 ;
float a ;            //三角函数 sin (a), cos (a), 
float r ;             //圆半径 radius
int i, j, n ;
float x0,y0,x1,y1,x2,y2 ;  //作图
float dx1,dy1,dx,dy ;             //中心坐标
string ss, ss1, ss2,ss3 ;         //打印文字
 int p[16] ;        //set data   or  input  data
 int  p1[16],  p2[16], p3[16] ;    //data
 double pn ;   //显示数据,计算
 int ca, cr, cg, cb ;     //设置颜色 setColor (a,r,g,b)  
 int ppn ;   //计算
 int tb ;      //set tab, print 
 int k0, k1 ;    //圆720线 起终点

//*************************  


ArtGraphics5 (){  //艺术统计图立体环图(体积式)
//体积以样本值大小定高度
      cs.ClearDraw (0,src);   //清屏
      clearOutput();
      selectStyle () ; //图例样式选项设置
      cs.SetFillMode (1);//0不填色,1填色
         cs.SetColor (255,250,250,250);
      cs.DrawRect (0,4,720,600);   //back board
         cs.SetColor (255,140,140,140);
      cs.DrawRect (24,24,706,586);   //back      
         cs.SetColor (255,220,250,250);
      cs.DrawRect (20,20,700,580);   //back 
      cs.SetFillMode (0);//0不填色,1填色
         cs.SetColor (255,0,0,250);
      cs.DrawRect (20,20,700,580);   //back 
      cs.DrawRect (26,25,694,575);   //back 
 
  //艺术统计图样例: 图例 (立体环图, 体积凸显)
     cs.SetFillMode (1);//0不填色,1填色
            dx=360;  dy=260 ;   //center
         cs.SetColor (255,250,200,230);
      cs.DrawRect (50,80,150,280);   //样本值标底
      cs.DrawRect (555,80,665,280);   //样本值标底
          cs.SetStrokeWidth(1);    //线
          cs.SetTextStyle (0);  //1 粗体字
          cs.SetTextSize (24);
          cs.SetColor(255,0,0,250);
        cs.DrawText ("Group ",65,110);
           cs.SetTextSize (20);
        cs.DrawText (" A",55,140);
        cs.DrawText (" B",55,170);
        cs.DrawText (" C",55,200);
        cs.DrawText (" D",55,230);
        cs.DrawText (" E",55,260);

 //图例样本值:input data   
   p1[1]=4920; p1[2]=3000; p1[3]=1920; p1[4]=1560;  
   p1[5]=600;        //部门 12000
        k[0]=80;     //k=180,12点钟方向为0位
                            //k=0, 3点钟方向为0位
        k[1]=k[0]+p1[1]*72/1200 ;   //样本值合计12000
        k[2]=k[1]+p1[2]*72/1200 ;   //转换成整圆720线
        k[3]=k[2]+p1[3]*72/1200 ;
        k[4]=k[3]+p1[4]*72/1200 ;         
        k[5]=k[4]+p1[5]*72/1200 ;
 
 //绘制立体环图:
           cs.SetStrokeWidth(2);    //线
           dx=360;  dy=273 ;   r=160 ;  //center,  radius
        cs.SetColor(255,200,200,250);  
        cs.DrawCircle (dx+11, dy, 175);      //圆底色
 

cfb62aa433234b29aed705c85980edae.png 

45960804690b4c11b0c6e236f96b5091.png

 

//先绘制上面的第1块
           kn=p1[1]/200 ;
     for (t=1; t<=kn ; t++){   //底16线
      for (i= k[0]; i<=k[1] ; i++){  
              dx=360-3 ;  dy=265-t*2 ;   r=160 ;
             a=pi/360*i ;   
       cs.SetColor(255,200,50,130);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(- (r-120)*sin (a))+dy ;     //逆时针
        cs.DrawLine (x1,y1, x0,y0); 
            cs.SetColor(255,150,20,60);  //圆弧线
          cs.DrawCircle (x1,y1,1.5);    } 
              cs.Update ();      } //立体底色
 
     for (i= k[0]; i<=k[1] ; i++){  //绘制面上色
             dx=360-3 ;  dy=265-kn*2 ;
             a=pi/360*i ;   
         cs.SetColor(255,250,0,0);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(- (r-120)*sin (a))+dy ;     //逆时针
          cs.DrawLine (x1,y1, x0,y0);       
              cs.SetColor(255,250,210,200);  //圆弧线
          cs.DrawCircle (x0,y0,1.5);       
          cs.DrawCircle (x1,y1,1.5);      } //面上色
            a=pi/360*k[0] ;     
            x2=(float)(r*cos (a))+dx ;     //r=radius
            y2=(float)(- r*sin (a))+dy ;     //逆时针
            a=pi/360*k[0] ;     
            x3=(float)((r-120)*cos (a))+dx ;     //r=radius
            y3=(float)(- (r-120)*sin (a))+dy ;     //逆时针
         cs.DrawLine (x1,y1, x0,y0);      //分隔线
         cs.DrawLine (x3,y3, x2,y2);      //加分隔 

        cs.SetColor(255,250,0,0);   //色标字和%
    cs.DrawRect (80,1*30+90 ,140,1*30+115); //n=1
    cs.DrawRect (560,1*30+90 ,660,1*30+115); //n=1
            cs.SetColor(255,250,250,250);   
             pn=p1[1]*10 ;     //保留1位小数
             pn=pn/1200 ; 
           ss1=doubleToString (pn)+"%" ;
           ss2=intToString (p1[1]) ;
        cs.DrawText(ss2, 88,1*30+110);   //标样本值
            ma=pi/360*((k[0]+k[1])/2) ;
            x1=(float)((r-45)*cos (ma))+dx ;     
            y1=(float)(-(r-45)*sin (ma))+dy ;
         cs.DrawText (ss1,x1-20,y1+5);     //标%
        cs.Update () ; 
      sleep (1000) ;   //延迟1秒
     // return ;

 

b492a49a1ae048da87587b6ed5d78fa5.png 

//再绘制上面的第2块
          kn=p1[2]/200 ;
      for (t=1; t<=kn ; t++){   //底16线
      for (i= k[1]; i<=k[2]+1 ; i++){  
              dx=360-6 ;  dy=285-t*2 ;
           a=pi/360*i ;   
       cs.SetColor(255,180,90,0);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(- (r-120)*sin (a))+dy ;     //逆时针
       cs.DrawLine (x1,y1, x0,y0);     }  
             cs.Update ();     } //立体底色
 
     for (i= k[1]; i<=k[2]+1 ; i++){  //绘制面上色
             dx=360-6 ;  dy=285-kn*2 ;
             a=pi/360*i ;   
         cs.SetColor(255,250,150,0);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(- (r-120)*sin (a))+dy ;     //逆时针
        cs.DrawLine (x1,y1, x0,y0);       
            cs.SetColor(255,250,220,0);  //圆弧线
        cs.DrawCircle (x0,y0,1.5);      
        cs.DrawCircle (x1,y1,1.5);         }//面上色
            a=pi/360*k[1] ;     
            x2=(float)(r*cos (a))+dx ;     //r=radius
            y2=(float)(- r*sin (a))+dy ;     //逆时针
           a=pi/360*k[1] ;     
            x3=(float)((r-120)*cos (a))+dx ;     //r=radius
            y3=(float)(- (r-120)*sin (a))+dy ;     //逆时针
         cs.DrawLine (x1,y1, x0,y0);      //分隔线
         cs.DrawLine (x3,y3, x2,y2);      //加分隔线
 
        cs.SetColor(255,250,200,0);   //色标字和%
     cs.DrawRect (80,2*30+90 ,140,2*30+115); //n
     cs.DrawRect (560,2*30+90 ,660,2*30+115); //n
             cs.SetColor(255,250,250,250);   
             pn=p1[2]*10 ;     //保留1位小数
             pn=pn/1200 ; 
           ss1=doubleToString (pn)+"%" ;
           ss2=intToString (p1[2]) ;
        cs.DrawText(ss2, 88,2*30+110);   //标样本值
            ma=pi/360*((k[1]+k[2])/2) ;
            x1=(float)((r-45)*cos (ma))+dx ;     
            y1=(float)(-(r-45)*sin (ma))+dy ;
          cs.DrawText (ss1,x1-27,y1+5);     //标%
      cs.Update () ; 
      sleep (1000) ;   //延迟1秒
    // return ;

6cb69a04634f4766878f713b545f4f8e.png 

//再绘制上面的第5块
          kn=p1[5]/200 ;
     for (t=1; t<=kn ; t++){   //底16线
      for (i= k[4]; i<=k[5] ; i++){  
              dx=360+4 ;  dy=262-t*2 ;
           a=pi/360*i ;   // a/2 绘出的是半圆
       cs.SetColor(255,0,120,200);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(- (r-120)*sin (a))+dy ;     //逆时针
       cs.DrawLine (x1,y1, x0,y0);     }    } //立体底色

     for (i= k[4]; i<=k[5] ; i++){  //绘制面上色
             dx=360+4 ;  dy=262-kn*2 ;
             a=pi/360*i ;   
         cs.SetColor(255,0,200,250);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(- (r-120)*sin (a))+dy ;     //逆时针
        cs.DrawLine (x1,y1, x0,y0);       
            cs.SetColor(185,200,250,250);  //圆弧线
        cs.DrawCircle (x0,y0,1.5);      
        cs.DrawCircle (x1,y1,1.5);         } //面上色
            a=pi/360*k[4] ;     
            x2=(float)(r*cos (a))+dx ;     //r=radius
            y2=(float)(- r*sin (a))+dy ;     //逆时针
            a=pi/360*k[4] ;     
            x3=(float)((r-120)*cos (a))+dx ;     //r=radius
            y3=(float)(- (r-120)*sin (a))+dy ;     //逆时针
              cs.SetColor(205,200,250,250);  
         cs.DrawLine (x1,y1, x0,y0);      //分隔线
         cs.DrawLine (x3,y3, x2,y2);      //加分隔线

        cs.SetColor(255,0,200,250);   //色标字和%
    cs.DrawRect (80,5*30+90 ,140,5*30+115); //n
    cs.DrawRect (560,5*30+90 ,660,5*30+115); //n
             cs.SetColor(255,250,250,250);   
             pn=p1[5]*10 ;     //保留1位小数
             pn=pn/1200 ; 
           ss1=doubleToString (pn)+"%" ;
           ss2=intToString (p1[5]) ;
            tb=0 ;
          if (p1[5]<1000) tb=11 ;   //右齐
     cs.DrawText(ss2, 88+tb,5*30+110);   //标样本值
            ma=pi/360*((k[4]+k[5])/2) ;
            x1=(float)((r-45)*cos (ma))+dx ;     
            y1=(float)(-(r-45)*sin (ma))+dy ;
          cs.DrawText (ss1,x1-20,y1+8);     //标%
      cs.Update () ; 
      sleep (1000) ;   //延迟1秒
   //return ;

e1bbf137ad614b9398600646bfbb7e39.png 

//绘制第4块
           kn=p1[4]/200 ;
     for (t=1; t<=kn ; t++){   //底16线
        for (i= k[3]; i<=k[4] ; i++){  
              dx=360+6 ;  dy=277-t*2 ;
           a=pi/360*i ;   // a/2 绘出的是半圆
              cs.SetColor(255,140,40,220);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(- (r-120)*sin (a))+dy ;     //逆时针
       cs.DrawLine (x1,y1, x0,y0);     }    } //立体底色

     for (i= k[3]; i<=k[4] ; i++){  //绘制面上色
             dx=360+6 ;  dy=277-kn*2 ;
             a=pi/360*i ;   
         cs.SetColor(255,240,130,240);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(- (r-120)*sin (a))+dy ;     //逆时针
        cs.DrawLine (x1,y1, x0,y0);       
            cs.SetColor(255,250,220,250);  //圆弧线
        cs.DrawCircle (x0,y0,1.5);      
        cs.DrawCircle (x1,y1,1.5);         } //面上色
            a=pi/360*k[3] ;     
            x2=(float)(r*cos (a))+dx ;     //r=radius
            y2=(float)(- r*sin (a))+dy ;     //逆时针
            a=pi/360*k[3] ;     
            x3=(float)((r-120)*cos (a))+dx ;     //r=radius
            y3=(float)(- (r-120)*sin (a))+dy ;     //逆时针
         cs.DrawLine (x1,y1, x0,y0);      //分隔线
         cs.DrawLine (x3,y3, x2,y2);      //加分隔线

        cs.SetColor(255,240,130,240);   //色标字和%
    cs.DrawRect (80,4*30+90 ,140,4*30+115); //n
    cs.DrawRect (560,4*30+90 ,660,4*30+115); //n
             cs.SetColor(255,250,250,250);   
             pn=p1[4]*10 ;     //保留1位小数
             pn=pn/1200 ; 
           ss1=doubleToString (pn)+"%" ;
           ss2=intToString (p1[4]) ;
      cs.DrawText(ss2, 88,4*30+110);   //标样本值
            ma=pi/360*((k[3]+k[4])/2) ;
            x1=(float)((r-45)*cos (ma))+dx ;     
            y1=(float)(-(r-45)*sin (ma))+dy ;
          cs.DrawText (ss1,x1-27,y1+5);     //标%
      cs.Update () ; 
      sleep (1000) ;   //延迟1秒
  // return ;

b0be9f0ce8eb4e98a979bd9e75d8fd0e.png
  
//最后绘制下面的第3块 > 完成
           kn=p1[3]/200 ;
      for (t=1; t<=kn ; t++){   //底16线
      for (i= k[2]; i<=k[3] ; i++){  
              dx=360+3;  dy=284-t*2 ;
           a=pi/360*i ;   // a/2 绘出的是半圆
       cs.SetColor(255,0,120,0);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(- (r-120)*sin (a))+dy ;     //逆时针
       cs.DrawLine (x1,y1, x0,y0);     }    } //立体底色

 

     for (i= k[2]; i<=k[3] ; i++){  //绘制面上色
             dx=360+3 ;  dy=284-kn*2 ;
             a=pi/360*i ;   
         cs.SetColor(255,0,210,0);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(- (r-120)*sin (a))+dy ;     //逆时针
        cs.DrawLine (x1,y1, x0,y0);       
            cs.SetColor(255,0,250,0);  //圆弧线
        cs.DrawCircle (x0,y0,1.5);      
        cs.DrawCircle (x1,y1,1.5);         } //面上色
            a=pi/360*k[2] ;     
            x2=(float)(r*cos (a))+dx ;     //r=radius
            y2=(float)(- r*sin (a))+dy ;     //逆时针
            a=pi/360*k[2] ;     
            x3=(float)((r-120)*cos (a))+dx ;     //r=radius
            y3=(float)(- (r-120)*sin (a))+dy ;     //逆时针
         cs.DrawLine (x1,y1, x0,y0);      //分隔线
         cs.DrawLine (x3,y3, x2,y2);      //加分隔线

        cs.SetColor(255,0,230,0);   //色标字和%
    cs.DrawRect (80,3*30+90 ,140,3*30+115); //n
    cs.DrawRect (560,3*30+90 ,660,3*30+115); //n
             cs.SetColor(255,250,250,250);   
             pn=p1[3]*10 ;     //保留1位小数
             pn=pn/1200 ; 
           ss1=doubleToString (pn)+"%" ;
           ss2=intToString (p1[3]) ;
     cs.DrawText(ss2, 88,3*30+110);   //标样本值
            ma=pi/360*((k[2]+k[3])/2) ;
            x1=(float)((r-45)*cos (ma))+dx ;     
            y1=(float)(-(r-45)*sin (ma))+dy ;
          cs.DrawText (ss1,x1-25,y1+5);     //标%
      cs.Update () ; 

           cs.SetColor(255,0,0,250);
        cs.DrawText ("年龄段分析",560,110);
           cs.SetColor(255,250,250,250);
        cs.DrawText ("20-30岁",570,140);
        cs.DrawText ("30-40岁",570,170);
        cs.DrawText ("40-50岁",570,200);
        cs.DrawText ("50-60岁",570,230);
        cs.DrawText ("60岁以上",570,260);
      sleep (1000) ;   //延迟1秒
          
//题标:  艺术立体字制作
        cs.SetFillMode (1);//0不填色,1填色
        cs.SetTextStyle (1);
        cs.SetStrokeWidth(1);
        cs.SetTextSize (28);
        cs.SetColor(255,0,0,250);      
      cs.DrawText ("Art Graphics 📊",480,60) ;
      cs.SetTextSize (41);
         ss="艺术统计图:立体环图(凸显)" ;
      cs.SetColor(255,50,120,20);      //立体字
           cs.DrawText (ss,114,534);    //阴影
      cs.SetColor(255,0,250,0);
           cs.DrawText (ss,110,530);    //本字
      cs.SetFillMode (0);//0不填色,1填色
      cs.SetColor(255,250,150,0);
           cs.DrawText (ss,110,530);    //框线
       cs.Update ();
}//ArtGraphics5 ()

 

//**** END *****************
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/768988.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RDGCN翻译

RDGCN翻译 Relation-Aware Entity Alignment for Heterogeneous Knowledge Graphs 面向异质知识图谱的关系感知实体对齐 阅读时间&#xff1a;2024.03.24 领域&#xff1a;知识图谱&#xff0c;知识对齐 作者&#xff1a;Yuting Wu等人 PKU 出处&#xff1a;IJCAI Abstract…

HarmonyOS NEXT应用开发之听歌识曲水波纹特效案例

介绍 在很多应用中&#xff0c;会出现点击按钮出现水波纹的特效。 效果图预览 使用说明 进入页面&#xff0c;点击按钮&#xff0c;触发水波纹动画。再次点击按钮&#xff0c;停止水波纹动画。 实现思路 本例涉及的关键特性和实现方案如下&#xff1a; 要实现存在两个连续…

C++ - 类和对象(上)

目录 一、类的定义 二、访问限定符 public&#xff08;公有&#xff09; protected&#xff08;保护&#xff09; private&#xff08;私有&#xff09; 三、类声明和定义分离 四、外部变量和成员变量的区别与注意 五、类的实例化 六、类对象的模型 七、类的this指针…

TCP详解

一、TCP报文段结构 1、源端口号和目的端口号都是16位&#xff0c;范围从&#xff08;1-65535&#xff0c;0不可用&#xff09; 2、序列号&#xff1a;在建立连接时由内核生成的随机数作为其初始值&#xff0c;通过 SYN 报文传给接收端主机&#xff0c;每发送一次数据&#xff0…

C语言数据结构易错知识点(5)(插入排序、选择排序)

插入排序&#xff1a;直接插入排序、希尔排序 选择排序&#xff1a;直接选择排序、堆排序 上述排序都是需要掌握的&#xff0c;但原理不会讲解&#xff0c;网上有很多详尽地解释&#xff0c;本文章主要分享一下代码实现上应当注意的事项 1.直接插入排序&#xff1a; 代码实…

拥抱C++的深度和复杂性,挖掘更多可能 !——《C++20高级编程(第5版)》

&#xff0c;C难以掌握&#xff0c;但其广泛的功能使其成为游戏和商业软件应用程序中最常用的语言。即使是有经验的用户通常也不熟悉许多高级特性&#xff0c;但C20的发布提供了探索该语言全部功能的绝佳机会。《C20高级编程(第5版)》为C的必要内容提供了一个代码密集型、面向解…

(AtCoder Beginner Contest 325) ---- D - Printing Machine -- 题解

目录 D - Printing Machine&#xff1a; 题目大意&#xff1a; 思路解析&#xff1a; 代码实现&#xff1a; D - Printing Machine&#xff1a; 题目大意&#xff1a; 思路解析&#xff1a; 打印一次后&#xff0c;需要充电一微秒后才能再次打印就可以看作每微妙只能打印一…

【文献阅读】AlphaFold touted as next big thing for drug discovery — but is it?

今天来精读2023年10月发在《Nature》上的一篇新闻&#xff1a;AlphaFold touted as next big thing for drug discovery — but is it? (nature.com)https://www.nature.com/articles/d41586-023-02984-w Questions remain about whether the AI tool for predicting protein …

蓝桥杯基础练习详细讲解二(具体代码、解题思路、Python)

试题 基础练习 回文数 提交此题 评测记录 资源限制 内存限制&#xff1a;512.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 问题描述 1221是一个非常特殊的数&#xff0c;它从左边读和从右边读是一样的&#x…

C语言从入门到实战----C语言中内存函数的使用和模拟实现

目录 前言 1.memcpy 使用和模拟实现 2. memmove 使用和模拟实现 3. memset 函数的使用 4. memcmp 函数的使用 前言 在编程领域&#xff0c;内存管理是至关重要的一环&#xff0c;它确保了程序能够高效、稳定地运行。 C语言作为一门底层的编程语言&#xff0c;提供了一系…

Redis 教程系列之Redis 集群配置(十三)

1.Redis集群方案比较 主从模式 在软件的架构中,主从模式(Master-Slave)是使用较多的一种架构。主(Master)和从(Slave)分别部署在不同的服务器上,当主节点服务器写入数据时,同时也会将数据同步至从节点服务器,通常情况下,主节点负责写入数据,而从节点负责读取数据。…

橘子疾病检测4种YOLOV8

橘子检测YOLOV8&#xff0c;检测4种疾病&#xff0c;采用YOLOV8-NANO&#xff0c;训练得到PT模型转换成ONNX&#xff0c;最后OPENCV调用&#xff0c;支持C/PYTHON/ANDROID 橘子检测YOLOV8&#xff0c;检测4种疾病

2025汤家凤考研数学视频,基础网课百度网盘课程+PDF讲义资料

2025汤家凤大神及数学全程 docs.qq.com/doc/DTmtOa0Fzc0V3WElI 复制粘贴到浏览器&#xff0c;可以见所有的Ke 第一轮 夯实基础 1.阅读大纲考查要求&#xff0c;明确每章的学习目标&#xff1b; 2.按节学习数学理论基础知识&#xff0c;吃透书中例题&#xff1b; 3.学习每章…

【C语言】数组(一维、二维数组的简单介绍)

数组&#xff08;Array&#xff09; 数组概念 数组是一组相同数据类型元素的集合&#xff0c;属于一种简单的数据结构&#xff0c;从中可以得到三个有效信息 数组元素是同一数据类型的变量数组存放一个或者多个数据&#xff0c;但是数组元素个数不能为0数组中各元素可独立作为…

【Web APIs】DOM节点

目录 1.节点操作 1.1DOM节点 1.2查找节点 1.2.1父节点查找 1.2.2子节点查找 1.2.3兄弟节点查找 1.3增加节点 1.4克隆节点 1.5删除节点 2.时间对象 2.1实例化 2.2时间对象方法 2.3时间戳 3.重绘和回流 1.节点操作 1.1DOM节点 DOM节点&#xff1a;DOM树中的每一个…

CHAT~(持续更新)

CHAT&#xff08;持续更新&#xff09; 实现一个ChatGPT创建API设计页面布局业务操作技术架构 编码其他 实现一个ChatGPT 创建API 最简单也最需要信息的一步 继续往下做的前提 此处省略&#xff0c;想要获取接口创建方式联系 设计 页面布局 按照官网布局 业务操作 注册登…

绝地求生:PUBG七周年庆典开启!参与周年话题投稿赢丰厚奖励

为庆祝七周年&#xff0c;闲游盒PUBG官方准备了众多活动与奖励&#xff0c;一起在庆典中创造难忘的回忆吧&#xff01;七周年庆典期间游玩PUBG&#xff0c;参与 #乐在7中鸡味无穷# 周年话题投稿&#xff0c;即有机会赢取魔力甜心萨莉套装 2奖励。 参与方式 在小黑盒PUBG社区中…

贪心算法相关题目

文章目录 1. 什么是贪心&#xff1f;2. 分发饼干3. 摆动序列4. 最大子数组和5. 买卖股票的最佳时机 II6. 跳跃游戏7. 跳跃游戏 II8.K 次取反后最大化的数组和9.加油站10.分发糖果11.柠檬水找零 1. 什么是贪心&#xff1f; 贪心的本质是选择每一阶段的局部最优&#xff0c;从而…

第1篇:Mysql数据库表结构导出字段到Excel(一个sheet中)

package com.xx.util;import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook;import java.sql.*; import java.io.*;public class DatabaseToExcel {public static void main(String[] args) throws Exception {// 数据库连接配置String u…

Less-1(sqlmap手工注入攻击)--sqli

第一步&#xff1a;判断他是什么sql注入&#xff1f; 1 报错 1 and 12 -- 错误结果(--表示注释符) 1 and 11 -- 正确结果 第二步&#xff1a;判断返回字段数 ?id1 order by 3-- 正确显示结果 ?id1 order by 4--当列数为4时开始报错&#xff0c;所以只有三列 注&#xf…