修改C语言程序代码的错误

void printman(int x,int y)
{
gotoxy(y,x);
_AX=02;_CX=01;_AH=0xa;
geninterrupt(0x10);
}
为什么在code blocks 里面是错误的 、
错误提示:'_AX' undeclared (first use in this function)
该怎么修改

c

3个回答

_AX , _CX , _AH 是寄存器,geninterrupt(0x10); 是调用中断 0x10 。 估计只能在DOS 或者WINDOWS95 WIN31 等系统下运行,而 CodeBlocks不是一个编译器,只是运行IDE,它依赖于其他的编译器 比如 MinGW VC++ ,而这些编译器中默认没有 _AX , _CX , _AH 这些寄存器变量。所以报错说没有定义这些变量。要使用这些寄存器,有两种方式:
1 嵌入汇编指令
2 使用汇编语言,编译为 obj 然后链接到exe 中。

如果 codeblocks 调用 VS 那么可以 用
__asm {
mov ax,02
mov cx,01
mov ah,0ah
int 10
}
但是vs代码只是32位程序支持,64位不支持。
如果使用 MinGW 它支持嵌入AT&T 汇编,你可以百度一下它的格式。

但是你这段代码估计在win xp win7 win8 win10 上 不允许调用 int 10h 中断,会引发异常(在win10上试了,不行,其他系统没验证)

做一个dos 虚拟机,或者 win95虚拟机实验一下。应该能通过。

codeblocks 中使用的编译器是 vs 还是 mingW还是 其他的?
使用vc 编译器用下面的写法

 __asm { 
mov ax,02
mov cx,01
mov ah,0ah
int 10
}

使用mingW 编译器要用下面的写法.

     __asm__("movw $2, %ax\n\t"
    "movw $1,%cx\n\t"
    "movb $0x0a, %ah\n\t"
    "int  $0x10"
    );
qq_31382031
年轻的树 非常感谢
接近 2 年之前 回复

但是
__asm {
mov ax,02
mov cx,01
mov ah,0ah
int 10
}
这个代码在code blocks 里面显示的也是有错误的
expected string literal before ')' token

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
c语言问题修改错误代码我小白

题目描述 修改并补全代码,实现如下格式的整数数字输出。其中输出的第2、3、5、6个数值都占10个字符位置。 /* Begin : 待修改的代码 */ #include <stdio.h> int main() { float num1; //从控制台读入一个浮点数到变量num1中 scanf("%f", &num1); //第1个数默认格式输出;第2和3个数字占10个字符位置,小数格式默认 printf("num1=%f;\tnum1=%f;\tnum1=%f;\n", num1, num1, num1); //第1个数默认格式输出;第2和3个数字占10个字符位置,第1、2和3个数字小数占2位 printf("num1=%f;\tnum1=%f;\tnum1=%f;", num1, num1, num1); return 0; } /* End : 待修改的代码 */ 输入 浮点数 输出 指定格式的数据 样例输入 12.345 样例输出 num1=12.345000; num1= 12.345000; num1=12.345000 ; num1=12.35; num1= 12.35; num1=12.35 ;

一直格式错误 怎么改?

![图片说明](https://img-ask.csdn.net/upload/201912/21/1576906961_652607.jpg) #include"iostream" #include"stdio.h" #include"string.h" using namespace std; main() { int a[11][11],n,m; while(cin>>n>>m) { int i=0,j=0,count=1; memset(a,-1,sizeof(a)); a[0][0]=0; while(count<=n*m-1) { while(a[i][j+1]==-1&&j+1<m)a[i][++j]=count++%10; while(a[i+1][j]==-1&&i+1<n)a[++i][j]=count++%10; while(a[i][j-1]==-1&&j-1>=0)a[i][--j]=count++%10; while(a[i-1][j]==-1&&i-1>=0)a[--i][j]=count++%10; } for(i=0;i<n;i++) { for(j=0;j<m;j++) cout<<a[i][j]; cout<<"\r\n"; } cout<<"\r\n"; } return 0; }

C语言关于出现错误代码C2040 间接寻址级别不同的问题

这里是小白,在研究数组与指针时发现了问题。 在主函数外进行如下声明后程序正常运行: ``` #include<stdio.h> #include<string.h> char str[30] = "Hello world"; char *ptr = str; void main() {} ``` 而修改成如下却报错: ``` #include<stdio.h> #include<string.h> char str[30] = "Hello world"; char *ptr; ptr = str; void main() {} ``` 显示 C2040 “ptr”:“int”与“char *”的间接寻址级别不同 C4047 “初始化”:“int”与“char *”的间接级别不同 定义为int型仍然报类似的错 在VS2017与VC6环境情况相同 将两者放入主函数则都没有问题 新人懂得不多 希望各位能够详细解答 多谢了

数据结构,顺序表程序 C语言

/* 2017.10.15第一次编译 2017.10.17 修改 添加姓名搜索功能 2017.10.18 修改 修改new函数外观 */ #include<stdio.h> #include<stdlib.h> #include<malloc.h> #include<string.h> typedef struct { char num[20]; char name[20]; int score; }Node; typedef struct { Node *Elem; int max; }List; int a=-1; void new() { puts(" ***************************************** "); puts(" * 欢迎进入学生信息统计 * "); puts(" * 1.输入学生的人数 * "); puts(" * 2.显示学生信息 * "); puts(" * 3.根据姓名检索学生信息 * "); puts(" * 4.显示指定学生信息 * "); puts(" * 5.在指定位置插入学生信息 * "); puts(" * 6.删除指定位置学生信息 * "); puts(" * 7.统计学生个数信息 * "); puts(" * 8.输入ctrl+Z 或者 exit退出程序 * "); puts(" ***************************************** "); } void ListInsert(List L,int ad,Node p) //在指定位置之后插入 { int i; for(i=a;i>ad;i--) { L.Elem[i+1]=L.Elem[i]; L.Elem[ad+1] = p; } } void ListDelete(int n,List L) //删除指定位置的信息 { int i; for(i=a;i<=a;i++) L.Elem[i]=L.Elem[i+1]; } void InitList(int n,List L) //录入信息 { int i; for (i = 1;i<=n;i++) { printf("plz input number:"); scanf("%s",L.Elem[i].num); printf("plz input name:"); scanf("%s",L.Elem[i].name); printf("plz input score:"); scanf("%s",L.Elem[i].score); put("Input complete"); } Node polling(int ad,List L) //学号查询 { return L.Elem[ad]; } int SearchName(char nam,List L,Node p) //姓名查询 { int i; for(i=1;i<=a;i++) { if(strcmp(L.Elem[i].name,nam)==0) { p = L.Elem[i]; } else return 0; } int main() { int SearchName(); void InitList(); char cmp[20]; new(); int a1,a2; int ad; List L; L.max = 999; Node p; L.Elem = (Node *)malloc(sizeof (Node)*L.max); while(1) { printf("请输入菜单号:"); scanf("%d",a1); if(a1<1||a1>7) { puts("error\n"); continue; } if((a1!=1&&a1!=1)&&a == -1) { puts("您还未录入学生信息!ERROR!"); continue; } switch(a2) { case 1: if(a !=-1) { printf("您已经输入过学生信息"); break; } printf("请输入学生人数(0~999):"); scanf("%d",&a); if(a<=0||a>999) { printf("输入非法,请重新输入\n"); continue; } InitList(a,L); puts(""); break; case 2: printf("学号\t 姓名\t 成绩\n"); for(i = 1;i <= a;i++) { p=polling(i,L); printf("%s\t\t %s\t\t%d\t\t",p.num,p.name,p.score); } printf("OK\n"); break; case 3: scanf("%s",cmp); if(SearchName(cmp,L,p)) { puts("查找成功!"); puts("输出为:"); printf("学号:%s,\t 姓名:%s\t 成绩:%s\t",p.num,p.name,p.score); } else puts("查无此人\n"); printf("OK\n"); break; case 4: printf("请输入要查询的人的序号:"); scanf("%d",&i); if(i>a||i<=0) { puts("ERROR"); puts(""); break; } puts("查找成功"); puts("学生信息马上输出"); p=polling(i,L); printf("%s\t\t %s\t\t,&d\t\t",p.num,p.name,p.score); printf("OK!"); puts(""); break; case 5 : if(a == 999) { puts("对不起,顺序表已满,无法进行任何操作,请先删除无关数据"); puts(""); continue; } printf("请输入要插入的位置,数值(0~学生最大数"); while(scanf("%d",&ad)) { if(ad >999 && ad < 0) printf("输入非法,请重新输入:"); else break; } printf("请输入学号:"); scanf("%s",p.num); printf("请输入姓名:"); scanf("%s",p.name); printf("请输入成绩:"); scanf("%d",p.score); ListInsert(L,ad,p); a++; printf("OK"); printf("\n"); break; case 7: printf("学生总数为:%d",a); printf("OK!"); printf("\n"); break; } } printf("程序结束 按CTRL+z退出"); return 0; } 源代码如下 为什么总是出现两个错误,求大哥帮忙解决!

求助:怎么用C语言实现学生信息管理系统的密码保存与修改?

登陆函数如下(这里的登陆账号和密码是固定的),怎么使用文件来实现登陆密码的修改与保存呢? ``` int login()//登陆 { char account_number[20], password[20]; char exp_account_number[] = "1", exp_password[] = "1";//可设计用户文件替换,扩展读用户信息代码 --怎么实现 int n = 0; while(TRUE) { system("cls"); login_menu(); printf("\t\t账号:"); gets(account_number); printf("\t\t密码:"); gets(password); if (strcmp(account_number, exp_account_number) == 0 && strcmp(password, exp_password) == 0) { printf("\t\t欢迎进入系统,请稍候......\n"); Sleep(1000); return OK; } else { printf("\t\t密码输入错误,按任意键请重新输入\n"); getchar(); n++; if (n >= 3) { printf("\t\t连续输错3次,程序即将退出......\n"); Sleep(2000); exit(ERROR); } } } } ```

56. 程序改错C语言以下程序中函数cutpaste功能是?

56. 程序改错: 【要求】 1.按以下程序功能改正程序的错误。 2.可以修改语句中的一部分内容,调整语句次序,增加变量声明或编译预处理命令,但不能增加其他语句,也不能删去整条语句。 【程序功能】 以下程序中函数cutpaste功能是将line指向的数组中从下标为source开始的连续len个字符作为一个子串复制到一个临时数组中,并将这些字符从line指向的数组中删除;再将临时数组中子串追加到line指向数组中字符串的尾部。 【测试数据与运行结果】 测试字符串:"this is a test." source=5, len=2 输出:this a test. is 【含有错误的源程序】 #include<stdio.h> #include<conio.h> #include<string.h> void cutpaste(char *line,int source,int len); { char t[20]; int i,length=strlen(line); if(source>=length)return; for(i=0;i<len&&i<19&&source+i<length;i++) t[i]=line[source+i]; t[0]='\0'; strcpy(&line[source],&line[source+i]); strcpy(line,t); } int main() { char line[80]="this is a test."; cutpaste(line[80],5,2); puts(line); getch(); return 0; } 请改正并认真测试程序的正确性。将源代码以文本方式提交,不要直接提交文件。

以下代码怎样改正(C语言字符串问题)

``` #define STDC_WANT_LIB_EXT1 1 #include <stdio.h> #include <string.h> int main(void) { char preamble[] = "The joke is:\n\n"; char str[][40] = { "My dog has\'t got any nose.", "How does your dog smell then?\n", "My dog smells horrible.\n" }; unsigned int strCount = sizeof(str) / sizeof(str[0]); unsigned int length = 0; for (unsigned int i = 0; i < strCount; ++i) { length += strnlen_s(str[i], sizeof(str[i])); } **char joke[length + strnlen_s(preamble, sizeof(preamble)) + 1];** if (strncpy_s(joke, sizeof(joke), preamble, sizeof(preamble))) { printf("Error copying preamble to joke.\n"); return 1; } for (unsigned int i = 0; i < strCount; ++i) { if (strncat_s(joke, sizeof(joke), str[i], sizeof(str[i]))) { printf("Error copying string str[%u].", i); return 2; } } printf("%s", joke); return 0; } ``` 错误信息: 1>f:\code\c语言入门经典\字符串和文本的应用\joining_strings.c(21): error C2057: 应输入常量表达式 1>f:\code\c语言入门经典\字符串和文本的应用\joining_strings.c(21): error C2466: 不能分配常量大小为 0 的数组 1>f:\code\c语言入门经典\字符串和文本的应用\joining_strings.c(21): error C2133: “joke”: 未知的大小 1>f:\code\c语言入门经典\字符串和文本的应用\joining_strings.c(23): warning C4034: sizeof 返回 0 1>f:\code\c语言入门经典\字符串和文本的应用\joining_strings.c(31): warning C4034: sizeof 返回 0

C语言改错题求救!!!

C语言题目 [改错题]文本修改函数 Time Limit:1000MS Memory Limit:65535K 题型: 填空题 语言: 无限制 描述 从键盘录入文本,以#结束,对文本中出现的错误的人名“sith”,“smth”,“smih”,“Sith”,“Smth”,“Smih”,改为正确的人名“Smith”, 输出修改后的文本。下面代码是实现了该功能的程序,但指定位置处有错误,请改正错误。 #include <stdio.h> #include <stdlib.h> #include <string.h> char text[20000]; char out[20000]; char match[6][20]={"sith","smth","smih","Sith","Smth","Smih"}; int notLetter(char ch) { return !((ch>='a'&&ch<='z')||(ch>='A'&&ch<='Z')); } void modify(char *text, char *out) { int find,i,j; int size=strlen(text); for(i=0; i<size-4; i++) { /*************** Wrong ******************* find=0; for(j=0;j<6;j++) if(text[i]==match[j][0]&& text[i+1]==match[j][1]&& text[i+2]==match[j][2]&& text[i+3]==match[j][3]&& notLetter(match[j][4])) find=1; *out++=text[i]; ********************************************/ _______________________ } if(!find) { *out++=text[i];*out++=text[i+1];*out++=text[i+2];*out++=text[i+3];*out++=0; } } int main() { int size=0; while((text[size]=getchar())!='#') size++; text[size]=0; modify(text, out); printf("%s",out); return 0; }

c语言调试结束后,再次运行就会提示错误,求解

我每次调试完,关闭调试后,修改完,然后再次运行程序是总会提示cannot open Debug/chapter_8.exe for writing,怎么解决呀

c语言编程的反幂法修改,求大神帮助,在线等!!!

#include<stdio.h> #include<math.h> #define n 3 #define p 12 float max(float x[]) { int i; float max; max=x[0]; for(i=1;i<n;i++) if(fabs(x[i])>fabs(max)) max=x[i]; return max; } void main() { int i,j,r,k; float t1,t2,t3,t4,t,m=12,epsilon=1; float U[5][5],L[5][5],c[5][5],y[5]; float u[5]={1,1,1},v[5]={1,1,1}; float a[5][5]={{-8,1,4},{1,-2,1},{4,1,-2}}; for(i=0;i<=n-1;i++) { c[i][i]=a[i][i]-p; for(j=0;j<=n-1;j++) if(j!=i) c[i][j]=a[i][j]; } for(i=0;i<=n-1;i++) //LU分解 { U[0][i]=c[0][i]; L[i][i]=1; } for(i=0;i<=n-1;i++) L[i][0]=c[i][0]/U[0][0]; for(r=1;r<=n-1;r++) { for(i=r;i<=n-1;i++) { t1=0; for(j=0;j<=r-1;j++) t1+=L[r][j]*U[j][i]; U[r][i]=c[r][i]-t1; } if(r!=n-1) { for(i=r+1;i<=n-1;i++) { t2=0; for(j=0;j<=r-1;k++) t2+=L[i][j]*U[j][r]; L[i][r]=(c[i][r]-t2)/U[r][r]; } } } while(epsilon>=1e-3) { y[0]=u[0]; for(i=1;i<=n-1;i++) { t3=0; for(j=0;j<=i-1;j++) t3+=L[i][j]*y[j]; y[i]=u[i]-t3; } v[n-1]=y[n-1]/U[n-1][n-1]; for(i=n-2;i>=0;i--) { t4=0; for(j=i+1;j<=n-1;j++) t4+=U[i][j]*v[j]; v[i]=(y[i]-t4)/U[i][i]; } t=m; m=max(v); for(i=0;i<=n-1;i++) u[i]=v[i]/m; epsilon=fabs(m-t); k++; } printf("此矩阵的反幂法指定特征值为:%f\n",12+1.0/m); printf("此矩阵的反幂法的特征向量为:\n"); for(i=0;i<=n-1;i++) printf("%f\n",u[i]); } 程序运行的时候语句没有错误,可是结果出不来 ![图片说明](https://img-ask.csdn.net/upload/201706/04/1496572315_577057.png) (不知道为什么前面几段有些显示不出来,就放了截图)

代码没有错误,为什么程序没运行完就直接结束了?

![图片说明](https://img-ask.csdn.net/upload/201908/08/1565246195_162168.png) ![图片说明](https://img-ask.csdn.net/upload/201908/08/1565246218_224284.png) ``` //主要功能:实现带小数二进制和十进制之间数据的转换 #include <iostream.h> #include <windows.h> #include <fstream.h> #include <string> #include <math.h> using namespace std; const int TAILMAXLENTH=10;//定义十进制转换成二进制小数部分最大位数 const int DABAMAXLENTH=40;//定义原始数据的最大长度 const double ADDMENBERNUM=111.11;//定义一个加数用于检测数据真实可用 /********************************************************************************************************* *栈的部分 *********************************************************************************************************/ class Stack;//类Stack的声明 /* 定义一个链栈结点类Stacknode */ class Stacknode { friend class Stack;//申请友元类 private: Stacknode(Stacknode *nextp=NULL);//构造函数 Stacknode(int &newdata,Stacknode *nextp=NULL);//构造函数 int data;//数据元素 Stacknode *next;//递归定义指向后继结点的指针 }; /* Stacknode的实现部分 */ Stacknode::Stacknode(Stacknode *nextp)//构造函数 { next=nextp; } Stacknode::Stacknode(int &newdata,Stacknode *nextp)//构造函数 { data=newdata; next=nextp; } //结点类Stacknode的定义结束 /* 定义一个链栈类Stack */ class Stack { public: Stack();//创建一个空栈 ~Stack();//回收一个栈 void clear();//销毁一个栈 bool empty() const;//确定栈是否已空 bool push(int &item);//把数据压进栈 bool pop();//出栈 bool top(int &item) const;//取出栈顶元素 private: Stacknode *newnode(Stacknode *nextp=NULL); Stacknode *newnode(int &item,Stacknode *nextp=NULL);//创建新的结点 Stacknode *Stacktop; int Stacklength; }; /* Stack的实现部分 */ Stacknode *Stack::newnode(Stacknode *nextp)//创建新的结点,不带数据 { return new Stacknode(nextp); } Stacknode *Stack::newnode(int &item,Stacknode *nextp)//创建新的结点,数据域赋值 { return new Stacknode(item,nextp); } //以下为栈类Stack的函数定义 Stack::Stack()//创建一个空栈 { Stacktop=newnode();//创建一个栈顶指针初始化,相当于Stacktop=NULL;本链表没有用头结点 Stacklength=0; } Stack::~Stack()//回收一个栈 { clear(); delete Stacktop;//释放栈底 } void Stack::clear()//销毁一个栈 { //while(pop());//不停地出栈,而每次释放空间在出栈函数中完成 Stacknode *usednodep;//定义指针usednodep,准备指向出栈的结点 while(Stacktop->next!=NULL) { usednodep=Stacktop;//指向出栈的结点 Stacktop=Stacktop->next;//栈顶指针后移 delete usednodep;//释放空间 } } bool Stack::empty() const//确定栈是否已空 { return Stacklength<=0?true:false; } bool Stack::push(int &item)//数据进栈 { Stacknode *newnodep;//定义指针newnodep,准备指向申请的新结点 newnodep=newnode(item,Stacktop);//申请新结点,把数据存入,把指针域指向头指针 if(!newnodep)//如果没有申请到空间,返回失败 return false; Stacktop=newnodep;//改链,完成进栈 Stacklength++;//栈的长度增加 return true;//本次操作成功 } bool Stack::pop()//出栈,不要栈顶数据 { Stacknode *usednodep;//定义指针usednodep,准备指向出栈的结点 if(!empty())//判断是否栈空 { usednodep=Stacktop;//指向出栈的结点 Stacktop=Stacktop->next;//栈顶指针后移 // delete usednodep;//释放空间 Stacklength--;//栈的长度减少 return true;//本次操作成功 } return false;//否则本次操作失败 } bool Stack::top(int &item) const//取出栈顶数据返回去 { if(!empty())//如果栈不空,记录当前栈顶元素 { item=Stacktop->data;//通过item返回去 return true;//本次操作成功 } return false;//否则本次操作失败 } /********************************************************************************************************* *队列的部分 *********************************************************************************************************/ /* 定义一个结点类node */ class node { public: int data; node *next; }; /* 定义一个链队类Queue */ class Queue { private: node *rear; node *front; protected: int count;//计数器,统计结点个数即线性队列的长度 public: Queue();//构造函数 ~Queue();//析构函数 void clear(void);//清空链队 bool empty(void) const;//判断是否空队 bool retrieve(int &item) const;//读取队头 bool append(const int &item);//数据入队 bool serve();//数据出队 }; /* 类Queue的实现部分 */ Queue::Queue()//构造函数 { front=new node;//申请新结点,作为队头结点 front->next=NULL; rear=front;//队尾指针指向队头 count=0;//计数器清零,队列开始时没有实际数据 } Queue::~Queue()//析构函数 { clear();//删除所有数据,释放所有结点 delete front;//把头结点也释放掉 count=0;//计数器清零,队列开始时没有实际数据 } void Queue::clear(void)//清空链队 { node *searchp=front->next,*followp=front;//初始化两个指针 while(searchp!=rear) { followp=searchp; searchp=searchp->next; delete followp; } front->next=NULL;//保留了最后一个结点,就是头结点,并且链域置为空 rear=front; count=0;//计数器也清零 } bool Queue::empty(void) const//判断是否空链 { return count==0?true:false; } bool Queue::retrieve(int &item) const//读取队头 { if(empty())//处理意外 return false; item=front->next->data;//返回读取的数据 return true;//本次操作成功 } bool Queue::append(const int &item)//进队 { node *newnodep=new node; newnodep->data=item;//给数据赋值 rear->next=newnodep;//这一步可以看出有头结点 rear=rear->next;//改动队尾指针的位置 count++;//计数器加1 return true; } bool Queue::serve()//出队 { if(empty())//空队处理 return false; node *tempp=front->next; // item=tempp->data;//保存数据 front->next=tempp->next;//改变指针 delete tempp;//释放该结点 count--;//计数器减1 return true; } /********************************************************************************************************* *定义一个功能类NumSysConversion *********************************************************************************************************/ class NumSysConversion { private: int inter; float floater; Stack *stack; Queue *queue; public: NumSysConversion();//构造函数 ~NumSysConversion();//析构函数 bool check(char *array,int number);//检查输入数据是否符合要求 void change(char *array,int number);//将原始数据转化成数值 double change_to_aim(int tokind);//将原始数据转化成目标进制的数据 }; NumSysConversion::NumSysConversion()//构造函数 { stack=new Stack; queue=new Queue; inter=0; floater=0; } NumSysConversion::~NumSysConversion()//析构函数 { delete stack; delete queue; } bool NumSysConversion::check(char *array,int number)//检查输入数据是否符合要求 { bool flag=true; for(int i=0;array[i]!='\0';i++) { cout<<array[i]; if(array[i]-48>=number) { flag=false; break; } } return flag; } void NumSysConversion::change(char *array,int number)//将原始数据转化成数值 { int flag=0,j=0; for(int i=0;array[i]!='\0';i++) { if(array[i]=='.') { flag=1; continue; } if(flag==0)//取整数数据 inter=inter*number+array[i]-48; if(flag==1)//取小数数据 floater+=(float)(((int)array[i]-48)*(float)pow(number,--j)); } } double NumSysConversion::change_to_aim(int tokind)//将原始数据转化成目标进制的数据 { int count=0,temp,flag=0,num; double resnumb=0; //第一步:先将整数部分转换进制后的数据依次入栈 while(inter) { num=inter%tokind; stack->push(num); inter/=tokind; } //第二步:再将小数部分转换进制后的数据依次入队 while(floater&&count<TAILMAXLENTH) { queue->append(int(floater*tokind)); floater*=tokind; if(floater>=1) floater-=(int)floater; count++; } //第三步:显示栈和队中的数据并将其转换成可用数据 cout<<"数据转换后为:"; while(!stack->empty()) { stack->top(temp); stack->pop(); cout<<temp; resnumb=resnumb*tokind+temp; flag=1; } if(!queue->empty()) { if(flag==0) cout<<"0"; cout<<"."; count=-1; } while(!queue->empty()) { queue->retrieve(temp); queue->serve(); cout<<temp; resnumb+=temp*pow(tokind,count--); } cout<<endl; //第四步:清空栈和队中的数据 stack->clear(); queue->clear(); inter=0; floater=0; //第五步:将可用数据信息返回 return resnumb; } /* 定义一个实现进制转换功能的菜单处理类interfacebase */ class interfacebase { private: NumSysConversion NumSysConversiononface; public: void clearscreen(void);//清屏 void showmenu(void);//显示菜单函数 int userchoice(void);//用户的选项 void processmenu(int menuchoice);//菜单函数 }; /* 类interfacebase的实现部分 */ void interfacebase::clearscreen(void) { system("cls"); } void interfacebase::showmenu(void) { cout<<"进制转换功能菜单"<<endl; cout<<"================"<<endl; cout<<"1.十进制转换为二进制"<<endl; cout<<"2.二进制转换为十进制"<<endl; cout<<"0.结束程序"<<endl; cout<<"================"<<endl; } int interfacebase::userchoice(void) { int menuchoice; cout<<"请输入您的选择:"; cin>>menuchoice; return menuchoice; } void interfacebase::processmenu(int menuchoice) { switch(menuchoice)//根据用户的选择进行相应的操作 { case 1: { char array[10]={'0','.','1','2','5'}; int number=10; if(NumSysConversiononface.check(array,number)) cout<<"符合要求!"<<endl; else cout<<"不符合要求!"<<endl; NumSysConversiononface.change(array,number); cout<<NumSysConversiononface.change_to_aim(2)<<endl; cout<<"进制转换成功!"<<endl; } break; case 2: { char array[10]={'1','1','1','1'}; int number=2; if(NumSysConversiononface.check(array,number)) cout<<"符合要求!"<<endl; else cout<<"不符合要求!"<<endl; NumSysConversiononface.change(array,number); cout<<NumSysConversiononface.change_to_aim(10)<<endl; cout<<"进制转换成功!"<<endl; } break; case 0: exit(0); default: cout<<"对不起,您输入的功能编号有错!请重新输入!!!"<<endl; break; } } /* 程序主入口 */ void main(void) { int menuchoice;//定义变量,菜单选单项的选择 interfacebase interfacenow; system("color f0");//修改屏幕的背景色和字的颜色 interfacenow.clearscreen();//清屏 while(1)//永真循环 { interfacenow.showmenu();//显示菜单 menuchoice=interfacenow.userchoice();//获取用户的选择 interfacenow.processmenu(menuchoice);//处理用户的选择 system("pause");//暂停 interfacenow.clearscreen();//清屏 } }//主函数结束 ```

为什么dev c代码修改以后编译运行仍然运行出原结果?

改之前的代码如下,后来删除了82和148行的cout,编译结果却没有变化,重开了dev c也仍然没法解决这个问题。 更改后结果仍然未变 ![图片说明](https://img-ask.csdn.net/upload/201910/13/1570935477_686763.jpg) 编译似乎也无问题![图片说明](https://img-ask.csdn.net/upload/201910/13/1570935832_663589.png) 而如果把代码复制重新重新编译能正确获得结果。 ``` #include<iostream> using namespace std; typedef struct StackNode { char data; struct StackNode *next; }StackNode,*LinkStack; typedef struct QNode { char data; struct QNode *next; }QNode,*QueuePtr; typedef struct { QueuePtr front; QueuePtr rear; }LinkQueue; class check { private: public: LinkQueue Q; LinkStack S; int CreateStack(LinkStack &S); int PushStack(LinkStack &S,char e); int PopStack(LinkStack &S,char &e); int GetStack(LinkStack &S,char &e); int CreateQueue(LinkQueue &Q); int EnterQueue(LinkQueue &Q,char e); int DeleteQueue(LinkQueue &Q,char &e); int checking(LinkQueue &Q,LinkStack &S); }; int check::CreateStack(LinkStack &S) { S=new StackNode; if(!S) { cout<<"error"<<endl; return 0; } S=NULL; return 1; } int check::PushStack(LinkStack &S,char e) { StackNode *q; q=new StackNode; q->data=e; q->next=S; S=q; return 1; } int check::PopStack(LinkStack &S,char &e) { if(S==NULL) return 0; StackNode *p; e=S->data; p=S; S=S->next; delete p; return 1; } int check::GetStack(LinkStack &S,char &e) { e=S->data; return 1; } int check::CreateQueue(LinkQueue &Q) { Q.front=Q.rear=new QNode; if(!Q.front) return 0; Q.front->next=NULL; cout<<"请输入:(结束前请输入 / )"<<endl; char e; cin>>e; while(e!='/') { EnterQueue(Q,e); cin>>e; cout<<e<<" "; } return 1; } int check::EnterQueue(LinkQueue &Q,char e) { QNode *p; p=new QNode; p->next=NULL; p->data=e; Q.rear->next=p; Q.rear=Q.rear->next; return 1; } int check::DeleteQueue(LinkQueue&Q,char &e) { QNode *p; p=Q.front->next; e=p->data; Q.front->next=p->next; if(Q.rear==p) { Q.rear=Q.front; return 0; } delete p; return 1; } int check::checking(LinkQueue &Q,LinkStack &S) { int i=1,t=0; char e; while(i!=0) { i=DeleteQueue(Q,e); t++; if(e=='('||e=='[') { PushStack(S,e); } else if(e==']') { char c; PopStack(S,c); if(c!='[') { cout<<"error: can't find [ , position:"<<t<<endl; return 0; } } else if(e==')') { char c; PopStack(S,c); if(c!='(') { cout<<"error: can't find ( , position"<<t<<endl; return 0; } } } if(PopStack(S,e)) { cout<<"error: can't find ] or ) to combo"<<endl; return 0; } /*这个if执行对每个左括号都需要右括号来配对的判断,原题目并不做此要求*/ cout<<i<<" "; return 1; } int main() { class check C; C.CreateStack(C.S); C.CreateQueue(C.Q); int k=0; k=C.checking(C.Q,C.S); if(k==1) cout<<"error:0"<<endl; return 0; } ```

用C语言写一个小系统,要求登录时,输入密码错误三次后,必须等10分钟才能再次登录。

写一个小系统,要求登录时,输入密码错误三次后,必须等10分钟才能再次登录。怎么样实现?

vs2017中错误代码MSB403错误怎么修改?

在VS2017中取消SDL安全检查后,运行程序出现MSB403错误。以下为运行代码: #define LOCAL #define INF 1000000000 #include<stdio.h> int main() { #ifdef LOCAL freopen("data.in", "r", stdin); freopen("data.out", "w", stdout); #endif int x, count = 0, min = INF, max = -INF, sum = 0; while (scanf("%d", &x) == 1) { sum += x; if (x < min)min = x; if (x > max)max = x; count++; } printf("min=%d,max=%d,avearage=%.3f", min, max,(double)sum/count); return 0; } 运行错误列表:严重性 代码 说明 项目 文件 行 禁止显示状态 错误 MSB4030 “否”对于“CL”任务的“SDLCheck”参数是无效值。“SDLCheck”参数的类型为“System.Boolean”。 Project2 D:\vs\Common7\IDE\VC\VCTargets\Microsoft.CppCommon.targets 490 ``` ```

C语言:在子函数中修改结构变量中元素的值

要写一个处理学生成绩信息的程序,使用单向链表,创建,遍历已经没有问题,但在修改结点的数据时出现问题,输入数据后程序就停止运行。 修改的思路是先根据学号定位到指定结点,然后修改数据,修改函数如下 ``` void Correct(float *a,float *b,float *c,float *d,float *e,float *f) { printf("请依次输入学生正确的的英语 数学 物理 C语言成绩\n"); scanf("%f%f%f%f",a,b,c,d); *e=*a+*b+*c+*d; *f=*e/4; } ``` 程序执行到上面时总是出现问题,不知道是什么原因,也尝试过其他修改的方法:只传结点的地址,同样出现问题;查找与修改函数合并,找到结点直接修改也是有问题,不知道为什么,代码有些长,还希望有人可以指导一下,非常感谢。 完整代码如下: ``` #include<stdio.h> #include<stdlib.h> #include<string.h> struct stu{ char num[15]; char name[20]; float EngSco; float MathSco; float PhySco; float CSco; float TotalSco; float AveSco; int GoOn; struct stu * next; }; void PrtMenu(); void CreatList(struct stu **headp);/*创建链表并输入数据*/ void PrtInf(struct stu *headp);/*输出链表中的某些数据*/ void Correct(float *a,float *b,float *c,float *d,float *e,float *f);/*修改链表中某结点元素的数据*/ void PrtData(struct stu *headp);/*输出链表中的某些数据*/ struct stu* Search(struct stu *headp);/*定位需要修改的结点的地址*/ int main() { int choice; struct stu *head=NULL,*revise=NULL; Order: PrtMenu(); scanf("%d",&choice); if(choice<0||choice>5){ printf("指令错误,请重新输入指令\n"); goto Order; } else switch(choice) { case 0: system("CLS"); break; case 1: CreatList(&head);break; case 2: PrtInf(head);break; case 3: revise=Search(head); Correct(&(revise->EngSco),&(revise->MathSco),&(revise->PhySco),&(revise->CSco),&(revise->TotalSco),&(revise->AveSco));break; case 4: PrtData(head);break; case 5: return 0; } goto Order; return 0; } void PrtMenu() { printf("-----功能选择-----\n"); printf("0.清屏并显示菜单\n"); printf("1.输入学生信息\n"); printf("2.输出学生各项信息\n"); printf("3.修改学生指定数据项的内容\n"); printf("4.输出各位同学的学号、姓名、四门课的总成绩和平均成绩\n"); printf("5.退出系统\n"); printf("------------------\n"); printf("请输入指令前的序号\n"); } void CreatList(struct stu **headp) { struct stu *loc_head=NULL,*tail; loc_head=(struct stu*)malloc(sizeof(struct stu)); printf("请输入学生的学号\n"); scanf("%s",loc_head->num); printf("请输入学生的姓名\n"); scanf("%s",loc_head->name); printf("请依次输入学生的英语 数学 物理 C语言成绩\n"); scanf("%f%f%f%f",&loc_head->EngSco,&loc_head->MathSco,&loc_head->PhySco,&loc_head->CSco); loc_head->TotalSco=loc_head->EngSco+loc_head->MathSco+loc_head->PhySco+loc_head->CSco; loc_head->AveSco=loc_head->TotalSco/4; tail=loc_head; printf("继续输入请按1,输入完成请按0\n"); scanf("%d",&tail->GoOn); if(tail->GoOn==0) goto end; else while(1) { tail->next=(struct stu*)malloc(sizeof(struct stu)); tail=tail->next; printf("请输入学生的学号\n"); scanf("%s",tail->num); printf("请输入学生的姓名\n"); scanf("%s",tail->name); printf("请依次输入学生的英语 数学 物理 C语言成绩\n"); scanf("%f%f%f%f",&tail->EngSco,&tail->MathSco,&tail->PhySco,&tail->CSco); tail->TotalSco=tail->EngSco+tail->MathSco+tail->PhySco+tail->CSco; tail->AveSco=tail->TotalSco/4; printf("继续输入请按1,输入完成请按0\n"); scanf("%d",&tail->GoOn); if(!tail->GoOn) break; } end: tail->next=NULL; *headp=loc_head; } void PrtInf(struct stu *headp) { struct stu *current=headp; printf("学号\t姓名\t英语\t高数\t物理\tC语言\t\n"); while(current) { printf("%s\t%s\t%.2f\t%.2f\t%.2f\t%.2f\t\n",current->num,current->name,current->EngSco,current->MathSco,current->PhySco,current->CSco); current=current->next; } } void Correct(float *a,float *b,float *c,float *d,float *e,float *f) { printf("请依次输入学生正确的的英语 数学 物理 C语言成绩\n"); scanf("%f%f%f%f",a,b,c,d); *e=*a+*b+*c+*d; *f=*e/4; } void PrtData(struct stu *headp) { struct stu *current=headp; printf("学号\t姓名\t总分\t平均分\t\n"); while(current) { printf("%s\t%s\t%.2f\t%.2f\t\n",current->num,current->name,current->TotalSco,current->AveSco); current=current->next; } } struct stu* Search(struct stu *headp) { struct stu *current=headp; char aim[15]; int flag; printf("请输入要修改数据的学生的学号\n"); scanf("%s",aim); while(current) { flag=strcmp(current->num,aim); if(flag=0) break; else current=current->next; } return current; } ```

医院排队就诊问题(C语言实现)求大神帮忙查看一下如何修改这些错误

问题描述: 医院急诊科室,有医生1名 现有病人7名,先后到达 病人病情轻重各有不同(分3级,3级最重,1级最轻),重症的优先就诊;病症相同的,先来的先就诊。 模型假设: 1.病人挂完号后进入对应的科室,每位病人属性包括姓名,性别,和身份证号 2.一开始的时候,医生空闲(等待病人)。 3.有护士根据病人病情,给出病情优先级后,再排队。 4.排队的病人按照先后次序排队,重症的优先就诊,病症相同的,先来的先就诊。。 5.一位医生每次只能看一个病人。 解决方案模型: 1. 程序模拟医院排队就诊,程序开始输入病人资料(包括优先级,姓名,性别,和身份证号)。 2. 设置一个病人的优先队列,按照优先级由高到低,分段排队,最开头的是优先级最高的病人;如果优先级相同,那么按照先来后到的顺序排队。 3. 对病人队列有两种操作,pop与push,医生每次从病人队列里面pop一个病人,并打印病人信息(包括优先级,姓名,性别,和身份证号),直到队列空。 ———————————————— 运行输入: 请按照优先级,姓名,性别,和身份证号顺序输入: 1 吕雅畅 男 141130198509277099 1 卞丹丹 女 532925197204181629 2 潘德茂 男 500114197005227938 1 邬碧玉 女 620721198202232320 3 金慧雅 女 533123198508252640 2 岑俊茂 男 152526198707214777 3 毕采萱 女 420600198202107509 输出: 就诊顺序...... 3 金慧雅 女 533123198508252640 3 毕采萱 女 420600198202107509 2 潘德茂 男 500114197005227938 2 岑俊茂 男 152526198707214777 1 吕雅畅 男 141130198509277099 1 卞丹丹 女 532925197204181629 1 邬碧玉 女 620721198202232320 ``` #include<stdio.h> #include<stdlib.h> #include<string.h> #define OK 1 #define ERROR 0 int M=0; int N=0; typedef int Status; typedef struct ElemType { int level; char name[20]; char gender; char ID[20]; }ElemType; typedef struct Node //结点结构 { ElemType data; struct Node *next; }Node,*QueuePtr; typedef struct { QueuePtr front,rear; } LinkQueue; Status InitQueue(LinkQueue *Q) // 队列初始化 { QueuePtr p; p=(QueuePtr)malloc(sizeof(QueuePtr)); if(!p) { printf("内存分配失败"); return ERROR; } Q=(LinkQueue*)malloc(sizeof(LinkQueue)); if(!Q) { printf("内存分配失败"); return ERROR; } p->next=NULL; Q->front=p; Q->front=Q->rear; return OK; } Status EnQueue(LinkQueue *Q, ElemType e) //入队 { QueuePtr s=(QueuePtr)malloc(sizeof(Node)); if(!s) { printf("内存分配失败"); return ERROR; } s->data=e; s->next=NULL; Q->rear->next=s; //把拥有元素e的新节点s赋值给队尾的后继节点 Q->rear=s; //把当前s设置为队尾节点,rear指向s return OK; } Status DeQueue(LinkQueue *Q,ElemType *e) //出队 { QueuePtr p; if(Q->front==Q->rear) { printf("队列为空!"); return ERROR; } p=Q->front->next; // 将预删除的队头结点暂存给p *e=p->data; // 将删除的队头结点赋值给e 即出队 Q->front->next=p->next; // 将原队头结点后继p->next 赋值给现投结点后继 if(Q->rear==p) { Q->rear=Q->front; //若队头是队尾,则删除后将rear指向头结点 } free(p); return OK; } Status PriorEnQueue(LinkQueue *Q1,LinkQueue *Q2,ElemType *e) { if(e->level==3) { EnQueue(Q1,e); } else { EnQueue(Q2,e); } return OK; } Status PriorDeQueue(LinkQueue*Q1,LinkQueue*Q2) { ElemType *e; if(!(Q2->front==Q2->rear)) e=DeQueue(Q2,e); else if(!(Q1->front==Q1->rear)) e=DeQueue(Q1,e); else { return ERROR; } return OK; } Status GetIN(LinkQueue*Q1,LinkQueue*Q2,ElemType*e) { int i; int n; printf("请输入前来就诊的病人数量:"); scanf("%d",&n); for(i=M;i<M+N;i++) { printf("\n请输入第%d个病人的优先级:",i+1); scanf("%d",&e[i].level); printf("\n请输入第%d个病人的姓名:",i+1); scanf("%s",e[i].name); printf("\n请输入第%d个病人的性别:",i+1); scanf("%s",&e[i].gender); printf("\n请输入第%d个病人的身份证:",i+1); scanf("%s",e[i].ID); PriorEnQueue(Q1,Q2,e); } M=M+n; return OK; } Status ShowInformation(ElemType *e) { int i; LinkQueue *Q1,*Q2; InitQueue(Q1); InitQueue(Q2); PriorDeQueue(Q1,Q2); printf("优先级----------姓名----------性别----------身份证\n"); for(i=N;i<N;i++) { printf("\n"); printf("%5d %5s %5s %10s",e[i].level,e[i].name,&e[i].gender,e[i].ID); } return OK; } int main() { LinkQueue *Q1,*Q2; ElemType *e; GetIN(Q1,Q2,e); ShowInformation(e); return 0; } ``` ![图片说明](https://img-ask.csdn.net/upload/202004/04/1585990384_710920.png)

关于c语言中free以及指针的问题

先上代码 ``` #include <stdio.h> #include <string.h> #include <stdlib.h> struct ListNode { int val; struct ListNode *next; }; int main() { struct ListNode *ptr = (struct ListNode*)malloc(sizeof(struct ListNode)); ptr->val = 2; ptr->next = NULL; struct ListNode *qtr = (struct ListNode*)malloc(sizeof(struct ListNode)); qtr->val = 8; qtr->next = NULL; ptr->next = qtr; free(qtr);//对该句进行修改 while(ptr) { printf(" %d\n",ptr->val); ptr = ptr->next; } } ``` 1、输出错误,这里的原因如下,执行free后qtr并不是NULL;     free(pointer); 释放的是指针指向的内存。注意,释放的是内存,不是指针。指针并没有被释放,指针仍然指向原来的存储空间。指针是一个变量,只有程序结束时才被销毁。释放了内存空间后,原来指向这块空间的指针还是存在,只不过现在指针指向的内容是垃圾,是未定义的。因此,释放内存后把指针指向 NULL,防止指针在后面不小心又被解引用了。 --------------------- 作者:ForeverStrong 来源:CSDN 原文:https://blog.csdn.net/chengyq116/article/details/79079389 版权声明:本文为博主原创文章,转载请附上博文链接! 2、将free(qtr);后面再添加qtr = NULL; 执行错误。 3、将free(qtr)改成qtr = NULL; 执行正确。 我想问的就是造成2、3的区别,在2中,free后,qtr与原来的链表已经没有联系了吗?个人推测,ptr->next在1里面指向依然是qtr,而qtr指向的是一个垃圾空间。在2里面,改变了qtr的值后,ptr->next为什么没有指向NULL? 感激不尽。

c语言“结构体”一直报错

按照网课输入下列代码,一直报错。 看起来应该是 结构体 部分有错 但是网课的代码就这么写的…… 求问大家怎么修改! #include<stdio.h> typedef struct Lnode *List; struct Lnode{ int a[100]; int length; }; int sequentialSearch(list tb1,int k); int main(void) { int n,key; int a[100]; scanf("%d",&n); for(int i = 0 ; i < n ; i++) scanf("%d",&a[i]); scanf("%d",&key); printf("%d "sequentialSearch(a,key)); } int sequentialSearch(list tb1,int k){ int i; tb1->a[0] = k; for(i = tb1->length; &&tb1->a[i] != k;i--) ; return i; } ``` ``` ![图片说明](https://img-ask.csdn.net/upload/201807/05/1530800128_17387.png)

c语言小白:为什么这段代码在编译的时候出错误,求大神帮忙解决

#include <stdio.h> #include <stdlib.h> #include <string.h> #define M 100 //数组最大个数 struct student { int num; char name[10]; char writer[10]; char press[10]; int data; float price; int kucun; int jieyue; }; typedef struct student BOOK; extern BOOK boo[M]; void AppendScore(BOOK *head); void PrintScore(BOOK *head,int i); //....删除、修改等函数省略 #include"book.h" int n=0; //记录存入信息的个数 /* 函数功能: 提供用户进行菜单选择 参数:void 返回值:char 返回用户选择的菜单项 */ char Menu(void) { char ch; printf("\n图书管理查询 \n"); printf(" 1.添加图书信息 \n"); printf(" 2.现存图书信息的显示 \n"); printf(" 3.查询 \n"); printf(" 5.删除 \n"); printf(" 6.修改 \n"); printf(" 0.退出\n"); printf("Please Input your choice:"); scanf(" %c", &ch); /*在%c前面加一个空格,将存于缓冲区中的回车符读入*/ return ch; } void main() { char ch; BOOK boo[M]; while (1) { ch = Menu(); /* 显示菜单,并读取用户输入 */ switch (ch) { case'1':AppendScore(boo ); /* 调用成绩添加模块 */ break; case'2':PrintScore(boo,n); /* 调用成绩显示模块 */ break; case'0':exit(0); /* 退出程序 */ printf("End of program!"); break; default:printf("Input error!"); break; } } } #include"book.h" extern int n; void AppendScore(BOOK *head) { FILE *fp; int i; BOOK *p; char next='Y'; printf("请输入数据:"); p=head+n; while(next=='Y') { printf("\n请输入编号:"); scanf("%d", &p->num); printf("请输入书名:"); scanf("%s", p->name); printf("请输入作者名字"); scanf("%s",p->writer); printf("请输入出版社名字"); scanf("%s",p->press); printf("请输入出版日期如2002年1月10号则输入20010110"); scanf("%d",&p->data); printf("请输入价格(精确到小数点后一位)"); scanf("%f",&p->price); printf("请输入馆藏书"); scanf("%d",&p->kucun); printf("请输入借阅数"); scanf("%d",&p->jieyue); n++; p++; getchar(); printf("继续输入吗(Y/N):"); scanf("%c",&next); } if((fp=fopen("boo.dat","wb"))==NULL) { printf("cannot open file\n"); return; } for(i=0;i<n;i++) if(fwrite(&boo[i],sizeof(BOOK),1,fp)!=1) printf("file writer errror\n"); fclose(fp); } void ShowTable(void) { printf("编号\t书名\t作者\t出版社\t出版日期\t价格\t馆藏数\t借阅数\n"); } void PrintScore(BOOK *head,int n) { FILE *fp; int i; ShowTable(); if((fp=fopen("boo.dat","rb"))==NULL) { printf("cannot open file\n"); exit(0); } for(i=0;i<n;i++) { fread(&boo[i],sizeof(BOOK),1,fp); printf("%10d%10s%10s%11s%12s%10f%11d%11d\n",boo[i].num,boo[i].name,boo[i].writer,boo[i].press,boo[i].data,boo[i].price,boo[i].kucun,boo[i].jieyue); } fclose(fp); }

大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了

大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

你以为这样写Java代码很6,但我看不懂

为了提高 Java 编程的技艺,我最近在 GitHub 上学习一些高手编写的代码。下面这一行代码(出自大牛之手)据说可以征服你的朋友,让他们觉得你写的代码很 6,来欣赏一下吧。 IntStream.range(1, 5).boxed().map(i -&gt; { System.out.print("Happy Birthday "); if (i == 3) return "dear NAME"...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

程序员写出这样的代码,能不挨骂吗?

当你换槽填坑时,面对一个新的环境。能够快速熟练,上手实现业务需求是关键。但是,哪些因素会影响你快速上手呢?是原有代码写的不够好?还是注释写的不够好?昨夜...

带了6个月的徒弟当了面试官,而身为高级工程师的我天天修Bug......

即将毕业的应届毕业生一枚,现在只拿到了两家offer,但最近听到一些消息,其中一个offer,我这个组据说客户很少,很有可能整组被裁掉。 想问大家: 如果我刚入职这个组就被裁了怎么办呢? 大家都是什么时候知道自己要被裁了的? 面试软技能指导: BQ/Project/Resume 试听内容: 除了刷题,还有哪些技能是拿到offer不可或缺的要素 如何提升面试软实力:简历, 行为面试,沟通能...

优雅的替换if-else语句

场景 日常开发,if-else语句写的不少吧??当逻辑分支非常多的时候,if-else套了一层又一层,虽然业务功能倒是实现了,但是看起来是真的很不优雅,尤其是对于我这种有强迫症的程序"猿",看到这么多if-else,脑袋瓜子就嗡嗡的,总想着解锁新姿势:干掉过多的if-else!!!本文将介绍三板斧手段: 优先判断条件,条件不满足的,逻辑及时中断返回; 采用策略模式+工厂模式; 结合注解,锦...

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

2020阿里全球数学大赛:3万名高手、4道题、2天2夜未交卷

阿里巴巴全球数学竞赛( Alibaba Global Mathematics Competition)由马云发起,由中国科学技术协会、阿里巴巴基金会、阿里巴巴达摩院共同举办。大赛不设报名门槛,全世界爱好数学的人都可参与,不论是否出身数学专业、是否投身数学研究。 2020年阿里巴巴达摩院邀请北京大学、剑桥大学、浙江大学等高校的顶尖数学教师组建了出题组。中科院院士、美国艺术与科学院院士、北京国际数学...

为什么你不想学习?只想玩?人是如何一步一步废掉的

不知道是不是只有我这样子,还是你们也有过类似的经历。 上学的时候总有很多光辉历史,学年名列前茅,或者单科目大佬,但是虽然慢慢地长大了,你开始懈怠了,开始废掉了。。。 什么?你说不知道具体的情况是怎么样的? 我来告诉你: 你常常潜意识里或者心理觉得,自己真正的生活或者奋斗还没有开始。总是幻想着自己还拥有大把时间,还有无限的可能,自己还能逆风翻盘,只不是自己还没开始罢了,自己以后肯定会变得特别厉害...

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

Python爬虫,高清美图我全都要(彼岸桌面壁纸)

爬取彼岸桌面网站较为简单,用到了requests、lxml、Beautiful Soup4

无代码时代来临,程序员如何保住饭碗?

编程语言层出不穷,从最初的机器语言到如今2500种以上的高级语言,程序员们大呼“学到头秃”。程序员一边面临编程语言不断推陈出新,一边面临由于许多代码已存在,程序员编写新应用程序时存在重复“搬砖”的现象。 无代码/低代码编程应运而生。无代码/低代码是一种创建应用的方法,它可以让开发者使用最少的编码知识来快速开发应用程序。开发者通过图形界面中,可视化建模来组装和配置应用程序。这样一来,开发者直...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

Java岗开发3年,公司临时抽查算法,离职后这几题我记一辈子

前几天我们公司做了一件蠢事,非常非常愚蠢的事情。我原以为从学校出来之后,除了找工作有测试外,不会有任何与考试有关的事儿。 但是,天有不测风云,公司技术总监、人事总监两位大佬突然降临到我们事业线,叫上我老大,给我们组织了一场别开生面的“考试”。 那是一个风和日丽的下午,我翘着二郎腿,左手端着一杯卡布奇诺,右手抓着我的罗技鼠标,滚动着轮轴,穿梭在头条热点之间。 “淡黄的长裙~蓬松的头发...

大牛都会用的IDEA调试技巧!!!

导读 前天面试了一个985高校的实习生,问了他平时用什么开发工具,他想也没想的说IDEA,于是我抛砖引玉的问了一下IDEA的调试用过吧,你说说怎么设置断点...

面试官:你连SSO都不懂,就别来面试了

大厂竟然要考我SSO,卧槽。

立即提问
相关内容推荐