线性表及栈与队列的实现 -- 栈

1.问题描述:
针对线性表或栈或队列(三者任选一种逻辑结构),按要求完成类(模板)的实现,并使用提供的main函数测试程序。

2.完成时有几种选择:
a.栈的实现。 b. 队列的实现。 c. 线性表的实现。

这里是栈的实现。务必按照提供的代码为基础进行补充。

template
class Stack {
public:
Stack(); //构造函数
bool empty() const ; //判断S是否为空栈
bool full() const; //判断栈S是否为满,
~Stack(); //将栈S清空
int size() const; //求栈S的长度,即栈S中的元素的个数
T & top() const; //返回栈S的栈顶元素
void push( const T &e ); //入栈操作,将数据元素e插入栈S的当前栈顶
T & pop(); //出栈操作,删除栈S的栈顶元素,并返回其值
private:
// 补充
};

//测试的main函数
int main() {
Stack sc; //stack of char
Stack si; //Stack of int
char ch = ' ';
// 不断输入字符到栈中,=结束
while (ch != '=') {
cin >> ch;
if (ch == 'a')
sc.push('A');
sc.push(ch);
}
cout << "top=" << sc.top() << "size=" << sc.size() << endl;
cout << "pop " << sc.pop() << endl;
while (!sc.empty())
cout << sc.pop()<< " ";
cout << endl;

 int x = 1;
 // 不断输入int到栈中,0结束
while (x != 0) {
     cin >> x;
     if (x > 10)
         si.push(10000);
     si.push(x);
 }
 cout << "top=" << si.top() << "size=" << si.size() << endl;
 cout << "pop " << si.pop() << endl;
 while (!si.empty())
     cout << si.pop()<< "/";
 cout << endl;

 return 0;

}

急求,用c++补充

c++

2个回答

#include<iostream> 
#include<cstdlib> 
using namespace std;

#define MAX 100

template <typename T>
class Stack {
public:
Stack(); //构造函数
bool empty() const ; //判断S是否为空栈
bool full() const; //判断栈S是否为满,
~Stack(); //将栈S清空
int size() const; //求栈S的长度,即栈S中的元素的个数
T & top() const; //返回栈S的栈顶元素
void push( const T &e ); //入栈操作,将数据元素e插入栈S的当前栈顶
T & pop(); //出栈操作,删除栈S的栈顶元素,并返回其值
private:
// 补充
T data[MAX];
int cur;
};

Stack::Stack()
{
    cur = 0;
}

bool Stack::empty() const
{
    cur = 0;
}

bool Stack::full() const
{
    return cur >= MAX;
}

Stack::~Stack() {}

int size() const { return cur; }

T & Stack::top()
{
    if (cur == 0) throw "stack is empty";
    return data[cur - 1];
}

void Stack::push( const T &e )
{
    if (cur >= MAX) throw "stack is full";
    data[cur++] = e;
}

T & Stack::pop()
{
    if (cur == 0) throw "stack is empty";
    return data[--cur];
}

//测试的main函数
int main() {
Stack sc; //stack of char
Stack si; //Stack of int
char ch = ' ';
// 不断输入字符到栈中,=结束
while (ch != '=') {
cin >> ch;
if (ch == 'a')
sc.push('A');
sc.push(ch);
}
cout << "top=" << sc.top() << "size=" << sc.size() << endl;
cout << "pop " << sc.pop() << endl;
while (!sc.empty())
cout << sc.pop()<< " ";
cout << endl;

 int x = 1;
 // 不断输入int到栈中,0结束
while (x != 0) {
     cin >> x;
     if (x > 10)
         si.push(10000);
     si.push(x);
 }
 cout << "top=" << si.top() << "size=" << si.size() << endl;
 cout << "pop " << si.pop() << endl;
 while (!si.empty())
     cout << si.pop()<< "/";
 cout << endl;

 return 0;
}

如果问题解决,请采纳下毕小宝的回答。如果还有问题,请追问

qq_45790374
qq_45790374 我重开了一个
3 个月之前 回复
caozhy
贵阳老马马善福专业维修游泳池堵漏防水工程 回复qq_45790374: 重新开一个问题(不需要悬赏)吧,你这么贴分行都没有,前面的代码也将就看了,这个怎么看
3 个月之前 回复
qq_45790374
qq_45790374 因为有些报错,我改成了这样
3 个月之前 回复
qq_45790374
qq_45790374 private: // 补充 T data[MAX]; int cur; }; template <typename T> Stack<T>::Stack() { cur = 0; } template<typename T> bool Stack<T>::empty() const { cur = 0; } template<typename T> bool Stack<T>::full() const { return cur >= MAX; } template<typename T> Stack<T>::~Stack() {} template<typename T> int Stack<T>::size() const { return cur; } template<typename T> T & Stack<T>::top() const { if (cur == 0) throw "stack is empty"; return data[cur - 1]; } template<typename T> void Stack<T>::push( const T &e ) { if (cur >= MAX) throw "stack is full"; data[cur++] = e; } template<typename T> T & Stack<T>::pop() { if (cur == 0) throw "stack is empty"; return data[--cur]; } //测试的main函数 int main() { Stack<char> sc; //stack of char Stack<int> si; //Stack of int char ch = ' '; // 不断输入字符到栈中,=结束 while (ch != '=') { cin >> ch; if (ch == 'a') sc.push('A'); sc.push(ch); } cout << "top=" << sc.top() << "size=" << sc.size() << endl; cout << "pop " << sc.pop() << endl; while (!sc.empty()) cout << sc.pop()<< " "; cout << endl; int x = 1; // 不断输入int到栈中,0结束 while (x != 0) { cin >> x; if (x > 10) si.push(10000); si.push(x); } cout << "top=" << si.top() << "size=" << si.size() << endl; cout << "pop " << si.pop() << endl; while (!si.empty()) cout << si.pop()<< "/"; cout << endl; return 0; }
3 个月之前 回复
caozhy
贵阳老马马善福专业维修游泳池堵漏防水工程 回复qq_45790374: 看我更新的回答
3 个月之前 回复
qq_45790374
qq_45790374 回复: 问题是已经改成文本,只是系统更新未出来
3 个月之前 回复
qq_45790374
qq_45790374 #include<iostream> #include<cstdlib> using namespace std; template <typename T> class Stack { public: Stack(); //构造函数 bool empty() const ; //判断S是否为空栈 bool full() const; //判断栈S是否为满, ~Stack(); //将栈S清空 int size() const; //求栈S的长度,即栈S中的元素的个数 T & top() const; //返回栈S的栈顶元素 void push( const T &e ); //入栈操作,将数据元素e插入栈S的当前栈顶 T & pop(); //出栈操作,删除栈S的栈顶元素,并返回其值 private: // 补充 }; //测试的main函数 int main() { Stack<char> sc; //stack of char Stack<int> si; //Stack of int char ch = ' '; // 不断输入字符到栈中,=结束 while (ch != '=') { cin >> ch; if (ch == 'a') sc.push('A'); sc.push(ch); } cout << "top=" << sc.top() << "size=" << sc.size() << endl; cout << "pop " << sc.pop() << endl; while (!sc.empty()) cout << sc.pop()<< " "; cout << endl; int x = 1; // 不断输入int到栈中,0结束 while (x != 0) { cin >> x; if (x > 10) si.push(10000); si.push(x); } cout << "top=" << si.top() << "size=" << si.size() << endl; cout << "pop " << si.pop() << endl; while (!si.empty()) cout << si.pop()<< "/"; cout << endl; return 0; }
3 个月之前 回复

C++ 实现栈的方法:https://www.cnblogs.com/zfc-java/p/6664330.html
C++ 实现线性表的方法:https://blog.csdn.net/qq_30611601/article/details/79516986
可以直接将代码拷贝到 https://tool.lu/coderunner 在线运行看结果。

wojiushiwo945you
毕小宝 回复qq_45790374: 我不会 C ++ ,只是认为这类基础实现,网上资源肯定有,就顺手搜罗了俩。
3 个月之前 回复
qq_45790374
qq_45790374 可以展示一下具体补充的代码吗
3 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
(修改报错的程序)线性表及栈与队列的实现 -- 栈
1.问题描述: 针对线性表或栈或队列(三者任选一种逻辑结构),按要求完成类(模板)的实现,并使用提供的main函数测试程序。 2.完成时有几种选择: a.栈的实现。 b. 队列的实现。 c. 线性表的实现。 这里是栈的实现。务必按照提供的代码为基础进行补充。 #include<iostream> #include<cstdlib> using namespace std; #define MAX 100 template <typename T> class Stack { public: Stack(); //构造函数 bool empty() const ; //判断S是否为空栈 bool full() const; //判断栈S是否为满, ~Stack(); //将栈S清空 int size() const; //求栈S的长度,即栈S中的元素的个数 T & top() const; //返回栈S的栈顶元素 void push( const T &e ); //入栈操作,将数据元素e插入栈S的当前栈顶 T & pop(); //出栈操作,删除栈S的栈顶元素,并返回其值 private: // 补充 T data[MAX]; int cur; }; template <typename T> Stack<T>::Stack() { cur = 0; } template<typename T> bool Stack<T>::empty() const { cur = 0; } template<typename T> bool Stack<T>::full() const { return cur >= MAX; } template<typename T> Stack<T>::~Stack() {} template<typename T> int Stack<T>::size() const { return cur; } template<typename T> T & Stack<T>::top() const { if (cur == 0) throw "stack is empty"; return data[cur - 1]; } template<typename T> void Stack<T>::push( const T &e ) { if (cur >= MAX) throw "stack is full"; data[cur++] = e; } template<typename T> T & Stack<T>::pop() { if (cur == 0) throw "stack is empty"; return data[--cur]; } //测试的main函数 int main() { Stack<char> sc; //stack of char Stack<int> si; //Stack of int char ch = ' '; // 不断输入字符到栈中,=结束 while (ch != '=') { cin >> ch; if (ch == 'a') sc.push('A'); sc.push(ch); } cout << "top=" << sc.top() << "size=" << sc.size() << endl; cout << "pop " << sc.pop() << endl; while (!sc.empty()) cout << sc.pop()<< " "; cout << endl; int x = 1; // 不断输入int到栈中,0结束 while (x != 0) { cin >> x; if (x > 10) si.push(10000); si.push(x); } cout << "top=" << si.top() << "size=" << si.size() << endl; cout << "pop " << si.pop() << endl; while (!si.empty()) cout << si.pop()<< "/"; cout << endl; return 0; } 这个程序报错 return data[cur - 1];这一行显示错误,怎么修改???
栈和队列都是限制存取点的线性结构
栈和队列都是限制存取点的线性结构这句话是什么意思? 不太理解,求教
这是一个关于数据结构线性表的问题
``` #include<iostream> using namespace std; #define OK 1 #define MAXSIZE 10000 #define OVERFLOW -1 int main() { typedef struct { char no[20]; char name[50]; float price; }Book; typedef struct { Book *elem; int length; }SqList; SqList L; return 0; } int a(SqList L) { return OK; } ``` 上面是我写的代码,编译后 --------------------Configuration: 线性表 - Win32 Debug-------------------- Compiling... 线性表.cpp E:\数据结构\线性表.cpp(24) : warning C4101: 'L' : unreferenced local variable E:\数据结构\线性表.cpp(28) : error C2065: 'SqList' : undeclared identifier E:\数据结构\线性表.cpp(28) : error C2146: syntax error : missing ')' before identifier 'L' E:\数据结构\线性表.cpp(28) : error C2059: syntax error : ')' E:\数据结构\线性表.cpp(29) : error C2143: syntax error : missing ';' before '{' E:\数据结构\线性表.cpp(29) : error C2447: missing function header (old-style formal list?) Error executing cl.exe. 线性表.exe - 5 error(s), 1 warning(s) 显示上述错误,为什么呢?
数据结构------线性表
某带头结点的非空单链表L中所有元素为非0整数,结点类型定义如下: typedef struct node { int data; struct node *next; } LinkNode; 设计一个尽可能高效的算法,将所有data值小于零的结点移到所有data值大于零的结点的前面。 算法提示: 顺序查找链表结点,如有data值小于0的结点则插入到首元结点处。
顺序表、链表和数组是逻辑结构还是物理(存储)结构?或者这两种结构都有描述?
数据结构中的线性结构也就是“线性表”是逻辑结构,现在可以肯定栈与队列都是存储结构,栈与队列都是线性表,顺序表和链表也是线性表,一维数组和顺序表又基本上是一回事,那么顺序表和链表也是存储结构吗? 主要是在网上看了很多人的回答,各种说法都有,所以想确认一下。
这是一个关于数据结构链表结点的相关问题
``` #include<iostream> #include<conio.h> #include<string> #include<iostream> using namespace std; typedef struct { string name; float price; }Book; typedef Book ElemType typedef struct LNode { ElemType Elem; LNode *Next; }*LNod,List; int main() { cout<<a[2]; getch(); return 0; } ``` 我定义了一个链表的结构,报错如下 --------------------Configuration: 线性表 - Win32 Debug-------------------- Compiling... 线性表.cpp E:\数据结构\线性表.cpp(15) : error C2143: syntax error : missing ';' before '<class-head>' E:\数据结构\线性表.cpp(15) : fatal error C1004: unexpected end of file found Error executing cl.exe. 线性表.exe - 2 error(s), 0 warning(s) 为什么呢
SqList结构体中的length是怎么改变线性表的长度的?求大神解答
//线性表的动态分配顺序存储结构。 struct SqList { ElemType * elem; //线性表存储空间的初始分配量; int length; // 线性表的长度; int listsize; // 当前分配的存储容量; }; struct SqList L; 为什么在 L.length = 0 的时候就代表线性表长度为零?它是如何实现的? 当 L.length = 0 时,难道不应该是结构体L中的length这一变量变为0吗?
下面关于线性表的叙述错误的是
下面关于线性表的叙述错误的是( )。 (A) 线性表采用顺序存储必须占用一片连续的存储空间 (B) 线性表采用链式存储不必占用一片连续的存储空间 (C) 线性表采用链式存储便于插入和删除操作的实现 (D) 线性表采用顺序存储便于插入和删除操作的实现
验证线性表及其上的基本操作。
要求 1、 定义单链表类及双向循环链表类。 2、 实现如下功能: 1 根据输入的测试数据(整型)按序从无到有创建一个单链表 L1。 比如,输入{9,2,5},单链表 L1 中结点顺序为,9->2->5 。 2 根据老师输入的测试数据(整型)创建一个非降序单链表 L2。比如, 输入{9,2,5},单链表 L2 中结点顺序为,2->5->9。 3 打印单链表 L2 中表头至表尾所有结点的数据域值,并输出单链表长度 以及这些结点数据域之和。 4 打印单链表 L1 中表尾至表头所有结点的数据域值,并输出最大值及最 小值。 5 由单链表 L1 生成一个双向循环链表 L3. 查找 L3 中任一结点,并输出从 该结点出发沿右指针域访问的线性表遍历序列。
这是一个关于数据结构链表的相关问题
``` #include<iostream> #include<conio.h> #include<string.h> #define OK 1 #define MAXSIZE 100 using namespace std; typedef int Status; typedef struct { char name[5]; float price; }Book; typedef Book ElemType; typedef struct LNode { ElemType data; struct LNode *next; }LNode,*LinkList; Status InitList(LNode *L) { L=new LNode; if(!L) exit(-1); else return OK; } int main() { getch(); return 0; } ``` 这是我写的全部代码 报错如下 --------------------Configuration: 线性表 - Win32 Debug-------------------- Compiling... 线性表.cpp E:\数据结构\线性表.cpp(27) : error C2018: unknown character '0xa3' E:\数据结构\线性表.cpp(27) : error C2018: unknown character '0xa9' E:\数据结构\线性表.cpp(28) : error C2146: syntax error : missing ')' before identifier 'exit' Error executing cl.exe. 线性表.exe - 3 error(s), 0 warning(s) 为什么呢?
线性表在顺序存储结构上的插入和删除
要求: (1)建立顺序线性表:在长度为Listsize的顺序表上存储1,3,5, 7 , 9组成的递增序列: (2)将一个指定数据(8)插入到有序序列中,使之仍然有序; insert( )(3)将有序序列中的5删除。Delete()
这是一个关于C语言引用的问题
我想测试引用的用法,敲了以下代码 ``` int main() { /*List tou; InitList(tou); List shou; InitList(shou); */ int &a=1; int b=2; int &c=b; getch(); return 0; } ``` 编译后出现下面错误 --------------------Configuration: 线性表 - Win32 Debug-------------------- Compiling... 线性表.cpp E:\数据结构\线性表.cpp(46) : error C2440: 'initializing' : cannot convert from 'const int' to 'int &' A reference that is not to 'const' cannot be bound to a non-lvalue Error executing cl.exe. 线性表.exe - 1 error(s), 0 warning(s) 我感觉非常奇怪的,首先这个转换错误出现一次,证明只有一次赋值出错。根据以往经验,我判断是&a=1出错。出错原因就是整型变量转化成引用整型,不合法。 &c=b也是整型变量转化成引用变量,为啥就合法了呢?
求救帮忙看一下我这个用C语言写的顺序线性表线性表合并为什么会有warning C4020: ?一直找不到原因
调试环境VC6.0 ``` #include<stdlib.h> #include<stdio.h> typedef int Status; // Status 是函数返回值类型,其值是函数结果状态代码。 #define OK 1 #define ERROR 0 #define OVERFLOW -2 #define List_Init_Size 100 //线性表存储空间初始分配量 #define Listincerment 10 //线性表存储空间的分配增量 typedef struct SqList { int *elem; int length; int listsize; //当前分配的存储容量() }SqList; Status InitList_Sq(SqList*L) {//初始化顺序线性表// L->elem=(int*)malloc(List_Init_Size*sizeof(int)); if(!L->elem)exit(OVERFLOW); //存储分配失败 L->length=0; return OK; } Status GetElem(SqList a,int i,int*e) { //读取元素 if(i<0||i>a.length) return ERROR; e=&a.elem[i-1]; //i-1存储第i个元素 return OK; } int ListLength(SqList L) { //计算长度 if(!L.elem)exit(ERROR); return L.length; } Status ListInsert_Sq(SqList *L, int i, int e) { //i位置之前插入新元素e if(i<1||i>L->length+1)return ERROR; if((L->length)>=(L->listsize)){ //当前存储空间已满,增加分配 int*newbase,*q,*p; newbase=(int*)realloc(L->elem,(L->listsize+Listincerment)*sizeof(int)); if(!newbase)exit(OVERFLOW);//存储分配失败} L->elem=newbase; //新的基址 L->listsize+=Listincerment; //增加容器容量 q=&(L->elem[i-1]); //q为插入位置 for(p=&(L->elem[L->length-1]);p>=q;--p) *(p+1)=*p; //插入位置及以后的元素后移 *q=e; //插入e ++L->length; } return OK;} void MergeList(SqList La,SqList Lb,SqList*Lc) { //线性表La和Lb中的数据元素按照值非递减排列。 int i,j,k,ai,bj; InitList_Sq(Lc); i=j=1;k=0; La.length=ListLength(La); Lb.length=ListLength(Lb); while((i<=La.length)&&(j<=Lb.length)) { GetElem(La,i,&ai); GetElem(Lb,j,&bj); if(ai<=bj) { ListInsert_Sq(Lc,++k,ai); ++i;} else{ListInsert_Sq(Lc,++k,bj);++j;} } while(i<=La.length) { GetElem(La,i,&ai); i++; ++k; InitList_Sq(Lc,k,&ai);} while(j<=Lb.length) { GetElem(Lb,j,&bj);j++; ++k; InitList_Sq(Lc,k,&bj); } } void output(SqList L) { int i; for(i=0;i<L.length;i++) { printf("%d ",L.elem[i]); } } void main() { SqList a,b,c; int i,j,k; InitList_Sq(&a); InitList_Sq(&b); printf("输入要写入链表a中元素的个数"); scanf("%d",&j); printf("输入每个元素"); for(i=1;i<=j;i++) { int e; scanf("%d",&e); ListInsert_Sq(&a,i,e); } printf("输入要写入链表b中元素的个数\n"); scanf("%d",&k); printf("输入每个元素"); for(j=1;j<=k;i++) { int e; scanf("%d",&e); ListInsert_Sq(&b,i,e); } MergeList(a,b,&c); output(c); } ``` ![图片说明](https://img-ask.csdn.net/upload/201912/02/1575268330_217932.png)
请问为什么我写的C语言中顺序存储的线性表的输出有这个错误
调试环境VC6.0 ``` #include<stdlib.h> #include<stdio.h> typedef int Status; // Status 是函数返回值类型,其值是函数结果状态代码。 #define OK 1 #define ERROR 0 #define OVERFLOW -2 #define List_Init_Size 100 //线性表存储空间初始分配量 #define Listincerment 10 //线性表存储空间的分配增量 typedef struct SqList { int *elem; int length; int listsize; //当前分配的存储容量() }SqList; Status InitList_Sq(SqList*L) {//初始化顺序线性表// L->elem=(int*)malloc(List_Init_Size*sizeof(int)); if(!L->elem)exit(OVERFLOW); //存储分配失败 L->length=0; return OK; } Status ListInsert_Sq(SqList *L, int i, int e) { //i位置之前插入新元素e if(i<1||i>L->length+1)return ERROR; if((L->length)>=(L->listsize)){ //当前存储空间已满,增加分配 int*newbase,*q,*p; newbase=(int*)realloc(L->elem,(L->listsize+Listincerment)*sizeof(int)); if(!newbase)exit(OVERFLOW);//存储分配失败} L->elem=newbase; //新的基址 L->listsize+=Listincerment; //增加容器容量 q=&(L->elem[i-1]); //q为插入位置 for(p=&(L->elem[L->length-1]);p>=q;--p) *(p+1)=*p; //插入位置及以后的元素后移 *q=e; //插入e ++L->length; } return OK;} void output(SqList L) { int i; for(i=0;i<L.length;i++) { printf("%d ",&L.elem[i]); } } void main() { SqList a; int i,j; InitList_Sq(&a); printf("输入要写入链表a中元素的个数"); scanf("%d",&j); printf("输入每个元素"); for(i=1;i<=j;i++) //小于等于 { int e; scanf("%d",&e); ListInsert_Sq(&a,i,e); } output(a); } ``` ![图片说明](https://img-ask.csdn.net/upload/201912/02/1575260361_988221.png)
数据结构 栈的定义 栈的定义
定义:栈是限定仅在表头进行插入和删除操作的线性表。 栈定义用的是数组 那为什么只能在头插入和删除 实际上到底什么啊
这是我写关于数据结构链表初始化功能的一个代码
``` #include<iostream> #include<conio.h> #include<string.h> #define OK 1 #define MAXSIZE 100 using namespace std; typedef int Status; #define OK 1 typedef struct { char name[5]; float price; }Book; typedef struct LNode { Book Elem; LNode *next; }LNode,*List; Status InitList(List *L) { L=new List(); if(!L) exit(-1); else (*L).next=NULL; return OK; } int main() { LNode L; L.Elem.price=1; List * LL; getch(); return 0; } ``` 为什么会报错 --------------------Configuration: 线性表 - Win32 Debug-------------------- Compiling... 线性表.cpp E:\数据结构\线性表.cpp(29) : error C2228: left of '.next' must have class/struct/union type Error executing cl.exe. 线性表.exe - 1 error(s), 0 warning(s) 大概是 (*L).next=NULL; 出了问题。我很纳闷,*L整体是个值结构体类型,给地址赋值,这么写没有问题啊
这是 一个关于数据结构的链表问题
``` #include<iostream> #include<conio.h> #include<string.h> #define OK 1 #define MAXSIZE 100 using namespace std; typedef int Status; typedef struct { char name[5]; float price; }Book; typedef Book ElemType; typedef struct LNode { ElemType data; struct LNode *next; }LNode,*LinkList; LNode *A; Status InitList(LNode *L) { L=new LNode; if(!L) exit(-1); else (*L).next=NULL; return OK; } int main() { LNode *L; InitList(*L); cout<<L; getch(); return 0; } ``` 这是我写的完整代码,就是生成了链表结点,还有初始化链表。 其中, ![图片说明](https://img-ask.csdn.net/upload/201912/22/1576944898_291707.png) 划线部分,两个参数我写的一样的,因为形参和实参要一致 但是却报错 --------------------Configuration: 线性表 - Win32 Debug-------------------- Compiling... 线性表.cpp E:\数据结构\线性表.cpp(45) : error C2664: 'InitList' : cannot convert parameter 1 from 'struct LNode' to 'struct LNode *' No user-defined-conversion operator available that can perform this conversion, or the operator cannot be called Error executing cl.exe. 线性表.exe - 1 error(s), 0 warning(s) 为甚么呢?
相见恨晚的超实用网站
搞学习 知乎:www.zhihu.com 简答题:http://www.jiandati.com/ 网易公开课:https://open.163.com/ted/ 网易云课堂:https://study.163.com/ 中国大学MOOC:www.icourse163.org 网易云课堂:study.163.com 哔哩哔哩弹幕网:www.bilibili.com 我要自学网:www.51zxw
花了20分钟,给女朋友们写了一个web版群聊程序
参考博客 [1]https://www.byteslounge.com/tutorials/java-ee-html5-websocket-example
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
字节跳动视频编解码面经
引言 本文主要是记录一下面试字节跳动的经历。 三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时
开源一个功能完整的SpringBoot项目框架
福利来了,给大家带来一个福利。 最近想了解一下有关Spring Boot的开源项目,看了很多开源的框架,大多是一些demo或者是一个未成形的项目,基本功能都不完整,尤其是用户权限和菜单方面几乎没有完整的。 想到我之前做的框架,里面通用模块有:用户模块,权限模块,菜单模块,功能模块也齐全了,每一个功能都是完整的。 打算把这个框架分享出来,供大家使用和学习。 为什么用框架? 框架可以学习整体
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成喔~) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch
深深的码丨Java HashMap 透析
HashMap 相关概念 HashTab、HashMap、TreeMap 均以键值对像是存储或操作数据元素。HashTab继承自Dictionary,HashMap、TreeMap继承自AbstractMap,三者均实现Map接口 **HashTab:**同步哈希表,不支持null键或值,因为同步导致性能影响,很少被使用 **HashMap:**应用较多的非同步哈希表,支持null键或值,是键值对...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
Python 基础(一):入门必备知识
目录1 标识符2 关键字3 引号4 编码5 输入输出6 缩进7 多行8 注释9 数据类型10 运算符10.1 常用运算符10.2 运算符优先级 1 标识符 标识符是编程时使用的名字,用于给变量、函数、语句块等命名,Python 中标识符由字母、数字、下划线组成,不能以数字开头,区分大小写。 以下划线开头的标识符有特殊含义,单下划线开头的标识符,如:_xxx ,表示不能直接访问的类属性,需通过类提供
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
JDK12 Collectors.teeing 你真的需要了解一下
前言 在 Java 12 里面有个非常好用但在官方 JEP 没有公布的功能,因为它只是 Collector 中的一个小改动,它的作用是 merge 两个 collector 的结果,这句话显得很抽象,老规矩,我们先来看个图(这真是一个不和谐的图????): 管道改造经常会用这个小东西,通常我们叫它「三通」,它的主要作用就是将 downstream1 和 downstre...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
8年经验面试官详解 Java 面试秘诀
作者 |胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。 Java程序员准备和投递简历的实...
相关热词 c# plc s1200 c#里氏转换原则 c# 主界面 c# do loop c#存为组套 模板 c# 停掉协程 c# rgb 读取图片 c# 图片颜色调整 最快 c#多张图片上传 c#密封类与密封方法
立即提问

相似问题