迷宫c语言实现,输出所有路径。 100C

用c语言实现代码。要求1,地图给定2,出发点终点给定。3,输出所有路径4,输出对应路径的伤害。5,完整的源代码和详细注释。6,发到763740324@qq.com图片说明

2个回答

这个深度优先和广度优先都可以的吧,网上搜一下迷宫问题的题解,会有很多现成代码的

qq_40611968
谢坡坡 回复T_world: 亲。能具体打一下不。或者具体的结构体定义。和实现算法。
2 年多之前 回复

加下我的QQ吧,QQ上聊,这个东西挺简单的,QQ:1299949836

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
为什么到最后一直无法输出迷宫路径?
#include<stdio.h> #include<malloc.h> #include<stdlib.h> typedef struct { int x; int y; }PosType; typedef struct { int ord; PosType seat; int di; }DataType; #include "SeqStack.h" #define MAXLENGTH 40 typedef int MazeType[MAXLENGTH][MAXLENGTH]; MazeType m; int x,y; PosType begin,end; int curstep = 1; void Print() { int i,j; for(i=0;i<x;i++) { for(j=0;j<y;j++) printf("%3d",m[i][j]); printf("\n"); } } void Init(int k) { int i,j,x1,y1; printf("请输入迷宫的行数,列数(包括外墙):"); scanf("%d,%d",&x,&y); for(i=0;i<x;i++) { m[0][i]=0; m[x-1][0]=0; } for(i=0;i<y-1;i++) { m[i][0]=0; m[i][y-1]=0; } for(i=1;i<x-1;i++) for(j=1;j<y-1;j++) m[i][j]=k; printf("请输入迷宫内墙单元数:"); scanf("%d",&j); printf("请依次输入迷宫内墙每个单元的行数,列数:\n"); for(i=1;i<=j;i++) { scanf("%d,%d",&x1,&y1); m[x1][y1]=0; } printf("迷宫结构如下:\n"); Print(); printf("请输入入口的行数,列数:"); scanf("%d,%d",&begin.x,&begin.y); printf("请输入出口的行数,列数:"); scanf("%d,%d",&end.x,&end.y); } int Pass(PosType b) { if(m[b.x][b.y]==1) return 1; else return 0; } void FootPrint(PosType a) { m[a.x][a.y]=curstep; } void NextPos(PosType *c,int di) { PosType direc[4]={{0,1}, {1,0},{0,-1},{-1,0}}; (*c).x+=direc[4].x; (*c).y+=direc[di].y; } void MarkPrint(PosType b){ m[b.x][b.y]=-1; } int MazePath(PosType start,PosType end) { SeqStack S; PosType curpos; DataType e; InitStack(&S); curpos=start; do { if(Pass(curpos)) { FootPrint(curpos); e.ord = curstep; e.seat = curpos; e.di = 0; PushStack(&S,e); curstep++; if(curpos.x==end.x&&curpos.y==end.y) return 1; NextPos(&curpos,e.di); } else { if(!StackEmpty(S)) { if(!StackEmpty(S)) { PopStack(&S,&e); curstep--; while(e.di==3&&!StackEmpty(S)) { MarkPrint(e.seat); PopStack(&S,&e); curstep; } if(e.di<3) { e.di++; PushStack(&S,e); curstep++; curpos=e.seat; NextPos(&curpos,e.di); } } } } }while(!StackEmpty(S)); return 0; } int main() { Init(1); if(MazePath(begin,end)) { printf("此迷宫从入口到出口的一条路径如下:\n"); Print(); } else printf("此迷宫没有从入口到出口的路径\n"); } //下面是seeqstack文件中的代码 #define StackSize 100 typedef struct { DataType stack[StackSize]; int top; }SeqStack; void InitStack(SeqStack *S) { S->top = 0; } int StackEmpty(SeqStack S) { if(S.top == 0) return 1; else return 0; } int GetTop(SeqStack S, DataType *e) { if(S.top<= 0) { printf("栈已经空!\n"); return 0; } else { *e = S.stack[S.top-1]; return 1; } } int PushStack(SeqStack *S, DataType e) { if(S->top>=StackSize) { printf("栈已满,不能将元素进栈!\n"); return 0; } else { S->stack[S->top]=e; S->top++; return 1; } } int PopStack(SeqStack *S, DataType *e) { if(S->top == 0) { printf("栈中已经没有元素,不能进行出栈操作!\n"); return 0; } else { S->top--; *e=S->stack[S->top]; return 1; } } int StackLength(SeqStack S) { return S.top; } void ClearStack(SeqStack *S) { S->top = 0; }
PTA:7-39 求迷宫最短通道(部分正确)
递归求解迷宫最短通道的总步长。输入一个迷宫,求从入口通向出口的可行路径中最短的路径长度。为简化问题,迷宫用二维数组 int maze[10][10]来存储障碍物的分布,假设迷宫的横向和纵向尺寸的大小是一样的,并由程序运行读入, 若读入迷宫大小的值是n(3<n<=10),则该迷宫横向或纵向尺寸都是n,规定迷宫最外面的一圈是障碍物,迷宫的入口是maze[1][1],出口是maze[n-2][n-2], 若maze[i][j] = 1代表该位置是障碍物,若maze[i][j] = 0代表该位置是可以行走的空位(0<=i<=n-1, 0<=j<=n-1)。求从入口maze[1][1]到出口maze[n-2][n-2]可以走通的路径上经历的最短的总步长。要求迷宫中只允许在水平或上下四个方向的空位上行走,走过的位置不能重复走。 输入格式: 输入迷宫大小的整数n, 以及n行和n列的二维数组(数组元素1代表障碍物,0代表空位) 输出格式: 若有可行的通道则输出一个整数,代表求出的通道的最短步长;若没有通道则输出"No solution" 输入样例: 10 1 1 1 1 1 1 1 1 1 1 1 0 0 1 0 0 0 1 0 1 1 0 0 1 0 0 0 1 0 1 1 0 0 0 0 1 1 0 0 1 1 0 1 1 1 0 0 0 0 1 1 0 0 0 1 0 0 0 0 1 1 0 1 0 0 0 1 0 0 1 1 0 1 1 1 0 1 1 0 1 1 1 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 1 上述输入代表的是如下这样一个迷宫: ![图片说明](https://img-ask.csdn.net/upload/202002/02/1580631291_613843.png) 其中红色的小方块是障碍物,蓝色的小方块是空位,白色的小圆连起来是一条从入口到出口的通道,两个圆之间代表一个步长。 输出样例: 14 请教一下哪里错了~:D 程序清单: ``` #include<stdio.h> #include<string.h> int maze[10][10]; int count=0,min; int endx,endy; int flag; int zou(int x,int y) { if(x==endx&&y==endy)//到终点 { flag=1; printf("%d",count); return 0; } maze[x][y]=1; if(flag)return 0; if(maze[x][y-1]==0)//向左 { count++; zou(x,y-1); count--; } if(maze[x+1][y]==0)//向下 { count++; zou(x+1,y); count--; } if(maze[x-1][y]==0)// 向上 { count++; zou(x-1,y); count--; } if(maze[x][y+1]==0)//向右 { count++; zou(x,y+1); count--; } return 0; } int main() { int n; scanf("%d",&n); for(int i=0;i<n;i++) { for(int j=0;j<n;j++) { scanf("%d",&maze[i][j]); } } int x=1,y=1; endx=endy=n-2; flag=0; zou(x,y); if(!flag) printf("No solution"); return 0; } ```
数据结构C++语言解决迷宫问题
标题: 迷宫问题 时 限: 100000 ms 内存限制: 100000 K 总时限: 3000 ms 描述: 迷宫问题 迷宫是一个二维矩阵,其中1为墙,0为路,3为入口,4为出口.要求从入口开始,从出口结束,按照 下,左,上,右 的顺序来搜索路径. 输入: 迷宫宽度w 迷宫高度h 迷宫第一行 迷宫第二行 ... 迷宫第h 行 输出: 入口横坐标1 入口纵坐标1 横坐标2 纵坐标2 横坐标3 纵坐标3 横坐标4 纵坐标4 ... 横坐标n-1 纵坐标n-1 出口横坐标n 出口纵坐标n 输入样例: 8 10 1 1 1 1 1 1 1 1 1 0 1 1 0 1 0 1 1 0 1 0 0 1 0 1 1 1 0 3 1 0 1 1 1 0 0 1 0 0 4 1 1 0 0 0 0 1 1 1 1 0 1 0 0 1 0 1 1 0 1 0 0 0 1 1 1 1 1 1 0 0 0 1 1 1 1 1 1 1 1 1 输出样例: 3 3 2 3 2 4 2 5 3 5 3 6 3 7 4 7 4 6 4 5 4 4 5 4 6 4
C语言迷宫算法,找不出问题在哪
#include<stdio.h> #include<stdlib.h> #define M 4 #define N 4 #define MaxSize 20 int mg[M+2][N+2]={ {1,1,1,1,1,1}, {1,0,0,0,1,1}, {1,0,1,0,0,1}, {1,0,0,0,1,1}, {1,0,0,0,0,1}, {1,1,1,1,1,1} }; struct { int i; int j; int pre; }Qu[MaxSize]; int front=-1,rear=-1; int minlen=0; int num=1; void print(int front) { int k=front,j; int ns=0; do { j=k; k=Qu[k].pre; ns++; }while(k!=-1); if(num==1) minlen=ns; if(ns==minlen) { ns=0; k=front; printf("第%d条最短路径(反向输出):\n",num++); do { j=k; printf("\t(%d,%d)",Qu[k].i,Qu[k].j); k=Qu[k].pre; if(++ns%5==0) printf("\n"); }while(k!=-1); printf("\n"); } } void mgpath(int x1,int y1,int x2,int y2) { int i,j,find=0,di,k; rear++; Qu[rear].i=x1;Qu[rear].j=y1;Qu[rear].pre=-1; while(front!=rear) { front++; for(di=0;di<4;di++) { switch(di) { case 0:i=Qu[front].i-1;j=Qu[front].j;break; case 1:i=Qu[front].i;j=Qu[front].j+1;break; case 2:i=Qu[front].i+1;j=Qu[front].j;break; case 3:i=Qu[front].i,j=Qu[front].j-1;break; } if(i>0&&j>0&&mg[i][j]==0&&(i!=Qu[Qu[front].pre].i||j!=Qu[Qu[front].pre].j)) { rear++; Qu[rear].i=i;Qu[rear].j=j; Qu[rear].pre=front; } } } for(k=0;k<=rear;k++) { if(Qu[k].i==x2&&Qu[k].j==y2) { find=1; print(k); } } if(!find) printf("不存在路径!\n"); } void main() { printf("所有迷宫([1,1]->[4,4])最短路径\n"); mgpath(1,1,M,N); }
一个数据结构上面路径可达性判断的问题,要求采用C语言技术
Problem Description 可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸的她再一次面临生命的考验。魔王已经发出消息说将在T时刻吃掉公主,因为他听信谣言说吃公主的肉也能长生不老。年迈的国王正是心急如焚,告招天下勇士来拯救公主。不过公主早已习以为常,她深信智勇的骑士LJ肯定能将她救出。 现据密探所报,公主被关在一个两层的迷宫里,迷宫的入口是S(0,0,0),公主的位置用P表示,时空传输机用#表示,墙用*表示,平地用.表示。骑士们一进入时空传输机就会被转到另一层的相对位置,但如果被转到的位置是墙的话,那骑士们就会被撞死。骑士们在一层中只能前后左右移动,每移动一格花1时刻。层间的移动只能通过时空传输机,且不需要任何时间。 Input 输入的第一行C表示共有C个测试数据,每个测试数据的前一行有三个整数N,M,T。 N,M迷宫的大小N*M(1 <= N,M <=10)。T如上所意。接下去的前N*M表示迷宫的第一层的布置情况,后N*M表示迷宫第二层的布置情况。 Output 如果骑士们能够在T时刻能找到公主就输出“YES”,否则输出“NO”。 Sample Input 1 5 5 14 S*#*. .#... ..... ****. ...#. ..*.P #.*.. ***.. ...*. *.#..
迷宫问题return;到底是返回到哪一步?
#include <stdio.h> int x1, y1, x2, y2;//起点坐标终点坐标 int min = 999999; //步数 int dir[4][2] = { -1,0,1,0,0,-1,0,1 }; int image[5][5] = { 0,0,1,1,1, 0,0,1,1,1, 0,0,0,1,1, 1,0,1,1,1, 0,0,0,0,0}; void dfs(int x, int y, int t) { int i, xx, yy; if (x == x2 && y == y2)//到达终点 { if (t<min) { min = t;//取最小值 } return; } image[x][y] = 1;//将走过的路设1,以免下次又以为这是一条路,又走回来 for (i = 0; i < 4; i++) { xx = x + dir[i][0]; yy = y + dir[i][1];//生成新的方向坐标 if (xx < 0 || xx >= 5 || yy < 0 || yy >= 5 || mg[xx][yy] == 1)//超出地图,或者为墙,则要重新换个方向走 continue; dfs(xx, yy, t + 1);//步数+1,以xx,yy为新的坐标,来进行对下次的方向进行选择又生成新的xxyy mg[xx][yy] = 0;//这一步是当走到终点了,或者是有一个xxyy坐标上下左右都不能走,则要将刚走过的路(之前设为墙了)恢复成路 } } int main() { printf("输入起点和终点坐标"); scanf_s("%d%d%d%d", &x1, &y1, &x2, &y2); dfs(x1, y1, 0); printf("%d", min); return 0; } min =t ;这步后面的return; 我是这样理解的:假如第一次t=4,第二次有更短的路径t=3;理论上输出min=3。但是第一次t小于9999已经终止函数输出min=4。虽然这样肯定是错的理解,哪但个地方错了大
蓝桥杯 测试提示运行错误怎么回事呢
/*问题描述   学霸抢走了大家的作业,班长为了帮同学们找回作业,决定去找学霸决斗。但学霸为了不要别人打扰,住在一个城堡里,城堡外面是一个二维的格子迷宫,要进城堡必须得先通过迷宫。因为班长还有妹子要陪,磨刀不误砍柴功,他为了节约时间,从线人那里搞到了迷宫的地图,准备提前计算最短的路线。可是他现在正向妹子解释这件事情,于是就委托你帮他找一条最短的路线。 输入格式   第一行两个整数n, m,为迷宫的长宽。   接下来n行,每行m个数,数之间没有间隔,为0或1中的一个。0表示这个格子可以通过,1表示不可以。假设你现在已经在迷宫坐标(1,1)的地方,即左上角,迷宫的出口在(n,m)。每次移动时只能向上下左右4个方向移动到另外一个可以通过的格子里,每次移动算一步。数据保证(1,1),(n,m)可以通过。 输出格式   第一行一个数为需要的最少步数K。   第二行K个字符,每个字符∈{U,D,L,R},分别表示上下左右。如果有多条长度相同的最短路径,选择在此表示方法下字典序最小的一个。 样例输入 Input Sample 1: 3 3 001 100 110 Input Sample 2: 3 3 000 000 000 样例输出 Output Sample 1: 4 RDRD Output Sample 2: 4 DDRR 数据规模和约定   有20%的数据满足:1<=n,m<=10   有50%的数据满足:1<=n,m<=50   有100%的数据满足:1<=n,m<=500。 */ #include<stdio.h> #include<string.h> #define UP 1 #define DOWN 2 #define RIGHT 3 #define LEFT 4 //起点 终点 int route(int n,int m,char (*map)[501]); void result(int n,int m,int position ,char (*map)[501]); char picture[501][501]; char picture_mark[501][501]={0}; int process_record[2][250001]={0}; char stack[250001]; int main(){ int n,m,i,position; scanf("%d",&n); scanf("%d",&m); for(i=0;i<n;i++){ scanf("%s",picture[i]); } position=route(n,m,picture); result(n,m,position,picture); return 0; } int route(int n,int m,char (*map)[501]) { int i,j,k,x,y; int position_x,position_y; //搜索顺序 URLD int last_x,last_y; int where_p=0,where_q=0,transition=0,transition_record=0; process_record[0][0]=0; process_record[1][0]=0; picture_mark[0][0]=-1; //初始化标记 while(1){ x=process_record[0][where_p]; y=process_record[1][where_p]; // printf("12 %d %d\n",where_p,where_q); if(x==(n-1)&&y==(m-1)){break;} if(map[x-1][y]=='0'&picture_mark[x-1][y]==0&&(x-1)>=0){ where_q++; process_record[0][where_q]=x-1; process_record[1][where_q]=y; picture_mark[x][y+1]=-1; } if(map[x][y+1]=='0'&&picture_mark[x][y+1]==0&&(y+1)<m){ where_q++; process_record[0][where_q]=x; process_record[1][where_q]=y+1; picture_mark[x][y+1]=-1; } if(map[x][y-1]=='0'&&picture_mark[x][y-1]==0&&(y-1)>=0){ where_q++; process_record[0][where_q]=x; process_record[1][where_q]=y-1; picture_mark[x][y-1]=-1; } if(map[x+1][y]=='0'&&picture_mark[x+1][y]==0&&(x+1)<n){ //字符0 where_q++; process_record[0][where_q]=x+1; process_record[1][where_q]=y; picture_mark[x+1][y]=-1; //遍历标记 } where_p++; } return where_p; } //逆向搜索结果 void result(int n,int m,int position ,char (*map)[501]){ int i,j; int difference_x,difference_y; int start=0,position_q,position_num; position_num=position; position_q=position-1; while(1){ difference_x=process_record[0][position]-process_record[0][position_q]; difference_y=process_record[1][position]-process_record[1][position_q]; if(difference_x==-1&&difference_y==0){ //反着来相邻的只会有一个 stack[start]='U'; start++; position=position_q; } else if(difference_x==0&&difference_y==-1){ stack[start]='L'; start++; position=position_q; } else if(difference_x==0&&difference_y==1){ stack[start]='R'; start++; position=position_q; } else if(difference_x==1&&difference_y==0){ stack[start]='D'; start++; position=position_q; } if(position==0){break;} position_q--; } //输出 start--; printf("%d\n",start+1); for(i=start;i>=0;i--){ printf("%c",stack[i]); } return ; } ``` ```
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
在中国程序员是青春饭吗?
今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...
《MySQL 性能优化》之理解 MySQL 体系结构
本文介绍 MySQL 的体系结构,包括物理结构、逻辑结构以及插件式存储引擎。
python自动下载图片
近日闲来无事,总有一种无形的力量萦绕在朕身边,让朕精神涣散,昏昏欲睡。 可是,像朕这么有职业操守的社畜怎么能在上班期间睡瞌睡呢,我不禁陷入了沉思。。。。 突然旁边的IOS同事问:‘嘿,兄弟,我发现一个网站的图片很有意思啊,能不能帮我保存下来提升我的开发灵感?’ 作为一个坚强的社畜怎么能说自己不行呢,当时朕就不假思索的答应:‘oh, It’s simple. Wait for me for a ...
一名大专同学的四个问题
【前言】   收到一封来信,赶上各种事情拖了几日,利用今天要放下工作的时机,做个回复。   2020年到了,就以这一封信,作为开年标志吧。 【正文】   您好,我是一名现在有很多困惑的大二学生。有一些问题想要向您请教。   先说一下我的基本情况,高考失利,不想复读,来到广州一所大专读计算机应用技术专业。学校是偏艺术类的,计算机专业没有实验室更不用说工作室了。而且学校的学风也不好。但我很想在计算机领...
复习一周,京东+百度一面,不小心都拿了Offer
京东和百度一面都问了啥,面试官百般刁难,可惜我全会。
达摩院十大科技趋势发布:2020 非同小可!
【CSDN编者按】1月2日,阿里巴巴发布《达摩院2020十大科技趋势》,十大科技趋势分别是:人工智能从感知智能向认知智能演进;计算存储一体化突破AI算力瓶颈;工业互联网的超融合;机器间大规模协作成为可能;模块化降低芯片设计门槛;规模化生产级区块链应用将走入大众;量子计算进入攻坚期;新材料推动半导体器件革新;保护数据隐私的AI技术将加速落地;云成为IT技术创新的中心 。 新的画卷,正在徐徐展开。...
轻松搭建基于 SpringBoot + Vue 的 Web 商城应用
首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行用户代码,而用户只需根据实际代码运行所消耗的资源进行付费。Fun: Fun 是一个用于支持 Serverless 应用部署的工具,能帮助您便捷地管理函数计算、API ...
Python+OpenCV实时图像处理
目录 1、导入库文件 2、设计GUI 3、调用摄像头 4、实时图像处理 4.1、阈值二值化 4.2、边缘检测 4.3、轮廓检测 4.4、高斯滤波 4.5、色彩转换 4.6、调节对比度 5、退出系统 初学OpenCV图像处理的小伙伴肯定对什么高斯函数、滤波处理、阈值二值化等特性非常头疼,这里给各位分享一个小项目,可通过摄像头实时动态查看各类图像处理的特点,也可对各位调参、测试...
2020年一线城市程序员工资大调查
人才需求 一线城市共发布岗位38115个,招聘120827人。 其中 beijing 22805 guangzhou 25081 shanghai 39614 shenzhen 33327 工资分布 2020年中国一线城市程序员的平均工资为16285元,工资中位数为14583元,其中95%的人的工资位于5000到20000元之间。 和往年数据比较: yea...
为什么猝死的都是程序员,基本上不见产品经理猝死呢?
相信大家时不时听到程序员猝死的消息,但是基本上听不到产品经理猝死的消息,这是为什么呢? 我们先百度搜一下:程序员猝死,出现将近700多万条搜索结果: 搜索一下:产品经理猝死,只有400万条的搜索结果,从搜索结果数量上来看,程序员猝死的搜索结果就比产品经理猝死的搜索结果高了一倍,而且从下图可以看到,首页里面的五条搜索结果,其实只有两条才是符合条件。 所以程序员猝死的概率真的比产品经理大,并不是错...
害怕面试被问HashMap?这一篇就搞定了!
声明:本文以jdk1.8为主! 搞定HashMap 作为一个Java从业者,面试的时候肯定会被问到过HashMap,因为对于HashMap来说,可以说是Java集合中的精髓了,如果你觉得自己对它掌握的还不够好,我想今天这篇文章会非常适合你,至少,看了今天这篇文章,以后不怕面试被问HashMap了 其实在我学习HashMap的过程中,我个人觉得HashMap还是挺复杂的,如果真的想把它搞得明明白...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
python爬取百部电影数据,我分析出了一个残酷的真相
2019年就这么匆匆过去了,就在前几天国家电影局发布了2019年中国电影市场数据,数据显示去年总票房为642.66亿元,同比增长5.4%;国产电影总票房411.75亿元,同比增长8.65%,市场占比 64.07%;城市院线观影人次17.27亿,同比增长0.64%。 看上去似乎是一片大好对不对?不过作为一名严谨求实的数据分析师,我从官方数据中看出了一点端倪:国产票房增幅都已经高达8.65%了,为什...
推荐10个堪称神器的学习网站
每天都会收到很多读者的私信,问我:“二哥,有什么推荐的学习网站吗?最近很浮躁,手头的一些网站都看烦了,想看看二哥这里有什么新鲜货。” 今天一早做了个恶梦,梦到被老板辞退了。虽然说在我们公司,只有我辞退老板的份,没有老板辞退我这一说,但是还是被吓得 4 点多都起来了。(主要是因为我掌握着公司所有的核心源码,哈哈哈) 既然 4 点多起来,就得好好利用起来。于是我就挑选了 10 个堪称神器的学习网站,推...
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
阿里面试,面试官没想到一个ArrayList,我都能跟他扯半小时
我是真的没想到,面试官会这样问我ArrayList。
曾经优秀的人,怎么就突然不优秀了。
职场上有很多辛酸事,很多合伙人出局的故事,很多技术骨干被裁员的故事。说来模板都类似,曾经是名校毕业,曾经是优秀员工,曾经被领导表扬,曾经业绩突出,然而突然有一天,因为种种原因,被裁员了,...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
良心推荐,我珍藏的一些Chrome插件
上次搬家的时候,发了一个朋友圈,附带的照片中不小心暴露了自己的 Chrome 浏览器插件之多,于是就有小伙伴评论说分享一下我觉得还不错的浏览器插件。 我下面就把我日常工作和学习中经常用到的一些 Chrome 浏览器插件分享给大家,随便一个都能提高你的“生活品质”和工作效率。 Markdown Here Markdown Here 可以让你更愉快的写邮件,由于支持 Markdown 直接转电子邮...
看完这篇HTTP,跟面试官扯皮就没问题了
我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟、醍醐灌顶的感觉。 最初在有网络之前,我们的电脑都是单机的,单机系统是孤立的,我还记得 05 年前那会儿家里有个电脑,想打电脑游戏还得两个人在一个电脑上玩儿,及其不方便。我就想为什么家里人不让上网,我的同学 xxx 家里有网,每...
史上最全的IDEA快捷键总结
现在Idea成了主流开发工具,这篇博客对其使用的快捷键做了总结,希望对大家的开发工作有所帮助。
C++(数据结构与算法):62---搜索树(二叉搜索树、索引二叉搜索树)
一、搜索树的复杂度分析 本文考察二叉搜索树和索引二叉搜索树 二叉搜索树的渐进性能可以和跳表媲美: 查找、插入、删除操作所需的平均时间为Θ(logn) 查找、插入、删除操作的最坏情况的时间为Θ(n) 元素按升序输出时所需时间为Θ(n) 虽然在最坏情况下的查找、插入、删除操作,散列表和二叉搜索树的时间性能相同,但是散列表在最好的情况下具有超级性能Θ(1) 不过,对于一个指定的关键...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
谁是华为扫地僧?
是的,华为也有扫地僧!2020年2月11-12日,“养在深闺人不知”的华为2012实验室扫地僧们,将在华为开发者大会2020(Cloud)上,和大家见面。到时,你可以和扫地僧们,吃一个洋...
AI 没让人类失业,搞 AI 的人先失业了
最近和几个 AI 领域的大佬闲聊 根据他们讲的消息和段子 改编出下面这个故事 如有雷同 都是巧合 1. 老王创业失败,被限制高消费 “这里写我跑路的消息实在太夸张了。” 王葱葱哼笑一下,把消息分享给群里。 阿杰也看了消息,笑了笑。在座几位也都笑了。 王葱葱是个有名的人物,21岁那年以全额奖学金进入 KMU 攻读人工智能博士,累计发表论文 40 余篇,个人技术博客更是成为深度学习领域内风向标。 ...
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆每天早上8:30推送 作者|Mr.K 编辑| Emma 来源|技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯...
最全最强!世界大学计算机专业排名总结!
我正在参与CSDN200进20,希望得到您的支持,扫码续投票5次。感谢您! (为表示感谢,您投票后私信我,我把我总结的人工智能手推笔记和思维导图发送给您,感谢!) 目录 泰晤士高等教育世界大学排名 QS 世界大学排名 US News 世界大学排名 世界大学学术排名(Academic Ranking of World Universities) 泰晤士高等教育世界大学排名 中国共...
作为一名大学生,如何在B站上快乐的学习?
B站是个宝,谁用谁知道???? 作为一名大学生,你必须掌握的一项能力就是自学能力,很多看起来很牛X的人,你可以了解下,人家私底下一定是花大量的时间自学的,你可能会说,我也想学习啊,可是嘞,该学习啥嘞,不怕告诉你,互联网时代,最不缺的就是学习资源,最宝贵的是啥? 你可能会说是时间,不,不是时间,而是你的注意力,懂了吧! 那么,你说学习资源多,我咋不知道,那今天我就告诉你一个你必须知道的学习的地方,人称...
那些年,我们信了课本里的那些鬼话
教材永远都是有错误的,从小学到大学,我们不断的学习了很多错误知识。 斑羚飞渡 在我们学习的很多小学课文里,有很多是错误文章,或者说是假课文。像《斑羚飞渡》: 随着镰刀头羊的那声吼叫,整个斑羚群迅速分成两拨,老年斑羚为一拨,年轻斑羚为一拨。 就在这时,我看见,从那拨老斑羚里走出一只公斑羚来。公斑羚朝那拨年轻斑羚示意性地咩了一声,一只半大的斑羚应声走了出来。一老一少走到伤心崖,后退了几步,突...
一个程序在计算机中是如何运行的?超级干货!!!
强烈声明:本文很干,请自备茶水!???? 开门见山,咱不说废话! 你有没有想过,你写的程序,是如何在计算机中运行的吗?比如我们搞Java的,肯定写过这段代码 public class HelloWorld { public static void main(String[] args) { System.out.println("Hello World!"); } ...
那个在阿里养猪的工程师,5年了……
简介: 在阿里,走过1825天,没有趴下,依旧斗志满满,被称为“五年陈”。他们会被授予一枚戒指,过程就叫做“授戒仪式”。今天,咱们听听阿里的那些“五年陈”们的故事。 下一个五年,猪圈见! 我就是那个在养猪场里敲代码的工程师,一年多前我和20位工程师去了四川的猪场,出发前总架构师慷慨激昂的说:同学们,中国的养猪产业将因为我们而改变。但到了猪场,发现根本不是那么回事:要个WIFI,没有;...
为什么程序猿都不愿意去外包?
分享外包的组织架构,盈利模式,亲身经历,以及根据一些外包朋友的反馈,写了这篇文章 ,希望对正在找工作的老铁有所帮助
leetcode88. 合并两个有序数组
给定两个有序整数数组nums1 和 nums2,将 nums2 合并到nums1中,使得num1 成为一个有序数组。 说明: 初始化nums1 和 nums2 的元素数量分别为m 和 n。 你可以假设nums1有足够的空间(空间大小大于或等于m + n)来保存 nums2 中的元素。 示例: 输入: nums1 = [1,2,3,0,0,0], m = 3 nums2 = ...
Java校招入职华为,半年后我跑路了
何来 我,一个双非本科弟弟,有幸在 19 届的秋招中得到前东家华为(以下简称 hw)的赏识,当时秋招签订就业协议,说是入了某 java bg,之后一系列组织架构调整原因等等让人无法理解的神操作,最终毕业前夕,被通知调往其他 bg 做嵌入式开发(纯 C 语言)。 由于已至于校招末尾,之前拿到的其他 offer 又无法再收回,一时感到无力回天,只得默默接受。 毕业后,直接入职开始了嵌入式苦旅,由于从未...
世界上有哪些代码量很少,但很牛逼很经典的算法或项目案例?
点击上方蓝字设为星标下面开始今天的学习~今天分享四个代码量很少,但很牛逼很经典的算法或项目案例。1、no code 项目地址:https://github.com/kelseyhight...
Python全栈 Linux基础之3.Linux常用命令
Linux对文件(包括目录)有很多常用命令,可以加快开发效率:ls是列出当前目录下的文件列表,选项有-a、-l、-h,还可以使用通配符;c功能是跳转目录,可以使用相对路径和绝对路径;mkdir命令创建一个新的目录,有-p选项,rm删除文件或目录,有-f、-r选项;cp用于复制文件,有-i、-r选项,tree命令可以将目录结构显示出来(树状显示),有-d选项,mv用来移动文件/目录,有-i选项;cat查看文件内容,more分屏显示文件内容,grep搜索内容;>、>>将执行结果重定向到一个文件;|用于管道输出。
​两年前不知如何编写代码的我,现在是一名人工智能工程师
全文共3526字,预计学习时长11分钟 图源:Unsplash 经常有小伙伴私信给小芯,我没有编程基础,不会写代码,如何进入AI行业呢?还能赶上AI浪潮吗? 任何时候努力都不算晚。 下面,小芯就给大家讲一个朋友的真实故事,希望能给那些处于迷茫与徘徊中的小伙伴们一丝启发。(下文以第一人称叙述) 图源:Unsplash 正如Elsa所说,职业转换是...
强烈推荐10本程序员必读的书
很遗憾,这个春节注定是刻骨铭心的,新型冠状病毒让每个人的神经都是紧绷的。那些处在武汉的白衣天使们,尤其值得我们的尊敬。而我们这些窝在家里的程序员,能不外出就不外出,就是对社会做出的最大的贡献。 有些读者私下问我,窝了几天,有点颓丧,能否推荐几本书在家里看看。我花了一天的时间,挑选了 10 本我最喜欢的书,你可以挑选感兴趣的来读一读。读书不仅可以平复恐惧的压力,还可以对未来充满希望,毕竟苦难终将会...
非典逼出了淘宝和京东,新冠病毒能够逼出什么?
loonggg读完需要5分钟速读仅需 2 分钟大家好,我是你们的校长。我知道大家在家里都憋坏了,大家可能相对于封闭在家里“坐月子”,更希望能够早日上班。今天我带着大家换个思路来聊一个问题...
Spring框架|JdbcTemplate介绍
文章目录一、JdbcTemplate 概述二、创建对象的源码分析三、JdbcTemplate操作数据库 一、JdbcTemplate 概述 在之前的web学习中,学习了手动封装JDBCtemplate,其好处是通过(sql语句+参数)模板化了编程。而真正的JDBCtemplete类,是Spring框架为我们写好的。 它是 Spring 框架中提供的一个对象,是对原始 Jdbc API 对象的简单...
谁说程序员不懂浪漫——我的C语言结婚请柬(附源码)
前言:但行好事,莫问前程——《增广贤文》 从上学起开始学C++,后面也做过H5,现在做Android。无论是学习用的,还是工作用的,上百个软件不止。但最另我骄傲的是,我用程序烂漫了一把。 用C++语言,利用WIN32框架写一个结婚请柬,文末附源码和使用方法,大家可以自行修改,记得帮我点赞哦。 点开程序,你的电脑像中毒一般,漫天的樱花从屏幕上方,伴随着歌声《今天你要嫁给我》,缓缓落下。 ...
立即提问