vc++6.0内关于s=(i++)*(i++)的问题

int i = 0;

s = (i++)*(i++)
printf(“%d”,s);

这个结果应该是多少?我个人分析应该是2,第一个i++使用的是1 然后i的值应该变成2然后第二个i使用的是2 然后i变成3 结果s的值应该是2 但是在vc++6.0的环境下运行结果为什么是1呢?新手求解。

3个回答

这个问题问了无数遍,我想这么告诉你。
就C++语言来说,这个是语言未定义行为,所谓语言未定义行为,就是在语言规范中没有规定遇到这样的代码应该输出什么。不同编译器输出结果可以不同。根据编译器实现的机制以及优化的机制,不同的编译器以它认为合理的方式产生代码。
就VC++6.0来说,你可以通过反汇编的方式搞清楚它究竟被编译成了什么,但是注意,即便相同的编译器,不同的优化选项和代码上下文输出也可能不同。

u011767611
Landpack x++在cpp里面重载时使用零时变量,在没有优化的情况下,x++要比++x慢。当然如你所说有些依赖于不同编译器。
5 年多之前 回复

各个编译器对这玩意都有不同解释,也会有不同结果,所以你知道前++和后++怎么回事就行了

楼主,询问下,本例中,你是否将 i 值看错了:

 int i=0; 

还是

 int i=1;

若是

 int i=1;

以我个人理解,对于VC++6.0,在赋值语句中,自增自减运算符若作为前缀形式 ,其运算优先级高于其它算术运算,即先按照“从右至左 ”的结合性进行自增自减运算,再进行其它运算;若作为后缀形式,其运算优先级低于其它算术运算,即先进行其它算术运算,再按 照“从 右至左 ”的结合性进行自增自减运算。
即对于本例,

#include<stdio.h>

int main()
{
    int i = 1;
    int s = (i++)*(i++);
    printf("s = %d,i= %d \n", s,i);

    system("pause");
    return 0;
} 

对s的赋值语句中,先使用i=1进行算术运算,之后再自增2次,即运算后s=1 ,i=3

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
【C语言】vc6.0运行程序过程中提示***.EXE已停止工作

在运行“添加”这一块时,输入完信息之后就提示***.EXE已停止工作,这是什么错? 代码如下 #include<stdio.h> #include<stdlib.h> #include<string.h> #include <windows.h> #include<conio.h> #define LENTEL sizeof(tel) #define ID struct tel struct tel { char name[15]; char tele[15]; char style[15]; char mail[20]; ID * next; }; ID *id = NULL; /*读取telephone.txt文件中的内容创建学生链表*/ ID* create() { ID *head; ID *p1,*p2; p2 = (ID*)malloc(LENTEL); head = p2; FILE *fp; if((fp = fopen("telephone.txt","r")) == NULL) { printf("联系人文件打开错误,请将telephone.txt放置与程序同一目录下!\n"); exit(0); } for(int i = 0; i<1;i++) fscanf(fp,"%*[^\n]%*c"); while(!feof(fp)) { p1 = (ID*)malloc(LENTEL); fscanf(fp,"%s%s%s%s",p1->name,p1->tele,p1->style,p1->mail); p1->next = NULL; p2->next = p1; p2 = p1; } fclose(fp); return head; } ID* findbyname(char name[]) { ID* p = id; ID* temp = NULL; while (p!=NULL) { if(strcmp(name,p->name) == 0) { temp = p; break; } else { p = p->next; } } return temp; } ID* findbytele(char tele[]) { ID* p = id; ID* temp = NULL; while (p!=NULL) { if(strcmp(tele,p->tele) == 0) { temp = p; break; } else { p = p->next; } } return temp; } /*判断这个联系人是否存在*/ bool Istel(char name[]) { ID *p = id->next; bool flag = false; while (p != NULL) { if(strcmp(p->name,name) == 0) { flag = true; } p=p->next; } return flag; } int add() { ID *newtel = NULL; ID *p = id; char tel_name[15]; char tel_tele[11]; char tel_style[15]; char tel_mail[20]; printf("\n------- 请输入学生基本信息 --------\n"); printf("姓名 电话 类别 邮箱\n"); printf("--------------------------------------\n"); scanf("%s%s%s%s",tel_name,tel_tele,tel_style,tel_mail); if(!Istel(tel_name)) { newtel = (ID*)malloc(LENTEL); strcpy(newtel->name,tel_name); strcpy(newtel->tele,tel_tele); strcpy(newtel->style,tel_style); strcpy(newtel->mail,tel_mail); newtel->next = NULL; for(p=p->next; p->next!=NULL; p=p->next); p->next = newtel; printf("\n联系人已添加成功!\n"); } else { printf("\n该联系人姓名已存在!\n"); } getch(); return 0; } void Print_Inquire_All() { void menu_print_out(); ID *p1 = id->next; menu_print_out(); while (p1!=NULL) { printf("%s\t%s\t%s\t%s\n",p1->name,p1->tele,p1->style,p1->mail); p1 = p1->next; } system("pause"); } void menu_print_out() { printf("\n---------------------------------\n"); printf("\n---------------------------------\n"); } /*主菜单*/ void menu(void) { void ReadBack(); printf(" ╭════════╮ \n"); printf("╭══════╣通讯管理系统V1.0╠══════╮\n"); printf("║ ╰════════╯ ║\n"); printf("║ 【1】添加数据 【3】退出系统 ║\n"); printf("║ ║\n"); printf("║ 【2】查询数据 ************* ║\n"); printf("║ ║\n"); printf("╰══════════════════════╯\n"); printf("◎请输入功能前的序号进入相应的工具:【 】\b\b"); int a = 0; a = getchar(); while(a!='1'&&a!='2'&&a!='3') { printf("error! please input the right number!\n"); putchar('\a'); getchar(); printf("◎请重新输入功能前的序号进入相应的工具:【 】\b\b"); a = getchar(); } switch(a) { case '1': add(); break; case '2': Print_Inquire_All(); case '3': ReadBack(); exit(0); break; } getchar(); } /*退出程序时将数据写回telephone.txt进行更新*/ void ReadBack() { FILE *TEL = fopen("telephone.txt","w"); ID *te = id->next; fprintf(TEL,"Tname Ttele Tstyle Tmail"); while (te != NULL) { fprintf(TEL,"\n%s %s %s %s",te->name,te->tele,te->style,te->mail); te = te->next; } fclose(TEL); } void Lunch() { FILE *fp; if((fp=fopen("telephone.txt","r")) == NULL) { FILE *fp; fp=fopen("telephone.txt","w+"); } else id = create(); menu(); } void main() { SetConsoleTitle("C语言通讯录管理系统"); Lunch(); }

vc++6.0内关于s=(i++)*(i++)的问题

int i = 0; s = (i++)*(i++) printf(“%d”,s); 这个结果应该是多少?我个人分析应该是2,第一个i++使用的是1 然后i的值应该变成2然后第二个i使用的是2 然后i变成3 结果s的值应该是2 但是在vc++6.0的环境下运行结果为什么是1呢?新手求解。

VC6.0中C与C++的不同之处

今天遇到一个情况,实在想不通。 这段代码在VC6.0的.c中错误提示【error C2143: syntax error : missing ';' before 'type'】。但在.cpp中却顺利通过。求解这是怎么回事 ``` #include <stdio.h> #include <stdlib.h> #define M 14 void NONO(); void fun( char (*t)[M], int *a ,int *c) { *a=0; *c=0; int i, j; //错误在这里 for(i=0;i<M;i++) for(j=0;j<M;j++) if(t[i][j]=='A')(*a)++; else if(t[i][j]=='C')(*c)++; } void get( char (*s)[M] ) { int i, j; for( i=0; i<M; i++ ) { for( j=0; j<M; j++) { s[i][j]=65+rand()%12; printf( "%c ",s[i][j]); } printf("\n"); } } int main() { char a[M][M]; int x, y; get (a); fun ( a, &x,&y ); printf("A = %d C = %d\n",x,y); return 0; } ```

vc6.0运行不了 调试的时候老是提示access violation

``` # include <stdio.h> # include <string.h> # define MAX 20 void main() { void search_s(char *s1,char *s2); char s1[MAX],s2[MAX]; printf("please input string 1:\n"); gets(s1); printf("please input string 2:\n"); gets(s2); search_s(s1,s2); } void search_s(char *s1,char *s2) //记录相同字符串 { int print_s(int *s1,int *s2,int p); int i,j,s=strlen(s1),t=strlen(s2); int s3[MAX]={0},s4[MAX],p=0,k; int d; for(i=0;i<s;i++) { for(j=0;j<t;j++) if(s1[i]==s2[j]) { s4[p]=i; //记录相同字符串起始字符位置 s3[p]=1;p++;//记录连续相同字符个数 for(k=1;s1[i+k] && s2[j+k];k++) { if(s1[i+k]==s2[j+k]) s3[p-1]=s3[p-1]+1; } } } d=print_s(s3,s4,p); for(i=s4[d];i<s4[d]+s3[d];i++) printf("%c",s1[i]); printf("\n"); } int print_s(int *s1,int *s2,int p) //找到打印位置 { int i,max=s1[0],k; for(i=1;i<p;i++) { if(max<s1[i]) { max=s1[i]; k=i; } } return k; } ```

VC6.0运行没问题的程序为什么到了VS2010里就运行异常了?

![图片说明](https://img-ask.csdn.net/upload/201608/06/1470464082_976215.png) 代码如下,一个基于控制台的计算器程序,异常原因好像是string类溢出? 小白一枚,平常在学校学的是VC6.0,并不清楚两种开发软件有什么区别也不知道该怎么改,求大神指点!! #include "StdAfx.h" #include<iostream> #include<cmath> #include<string> #include<iomanip> using namespace std; double D_Operate(double x,char op,double y)//双目运算符的运算定义 { double a; switch(op) { case'+': a=x+y;break; case'-': a=x-y;break; case'*': a=x*y;break; case'/': a=x/y;break; case'^': a=pow(x,y);break; } return a; } double S_Operate(char op,double x)//前缀单目运算符的运算定义 { double a; switch(op) { case's': a=sin(x);break; case'c': a=cos(x);break; case't': a=tan(x);break; case'l': a=log10(x);break; case'n': a=log(x);break; case'_': a=-x;break;//取负用下划线代替负号 定义为一元运算 } return a; } char Precede(char op1,char op2)//判断符号的优先级 op1在返回的结果符的左边 op2在右边 //用于判定运算符的优先级 以决定是把运算符压栈 还是把栈内的运算符弹出来进行计算 { if(((op1=='+'||op1=='-')&&(op2=='+'||op2=='-'||op2==')'||op2=='='))||\ ((op1=='*'||op1=='/')&&(op2=='+'||op2=='-'||op2=='*'||op2=='/'||op2==')'||op2=='='))\ ||(op1=='^'&&(op2=='+'||op2=='-'||op2=='*'||op2=='/'||op2==')'||op2=='='||op2=='s'||op2=='c'||op2=='t'||op2=='_'||op2=='l'||op2=='n'))\ ||((op1=='_'||op1=='s'||op1=='c'||op1=='t'||op1=='l'||op1=='n')&&(op2=='+'||op2=='-'||op2=='*'||op2=='/'||op2==')'||op2=='='||op2=='s'||op2=='c'||op2=='t'||op2=='_'||op2=='l'||op2=='n'))) return '>';//上述情况下 栈顶运算符优先级高于待定运算符 需弹栈 if((op1=='('&&op2==')')||(op1=='='&&op2=='=')) return '='; else return '<'; } int illegal_char(string s,int i)//非法输入字符判定函数 { int j=0; while(j<i) { if(s[j]>='0'&&s[j]<='9') j++; else if(s[j]=='+'||s[j]=='-'||s[j]=='*'||s[j]=='/'||s[j]=='.'||s[j]=='('||s[j]==')'||s[j]=='^'||s[j]=='!'||s[j]=='e'||s[j]=='_') j++; else if((s[j]=='p'&&s[j+1]=='i')||(s[j]=='l'&&s[j+1]=='n')) j+=2; else if((s[j]=='s'&&s[j+1]=='i'&&s[j+2]=='n')||(s[j]=='c'&&s[j+1]=='o'&&s[j+2]=='s')||(s[j]=='t'&&s[j+1]=='a'&&s[j+2]=='n')||(s[j]=='l'&&s[j+1]=='o'&&s[j+2]=='g')) j+=3; else { cout<<"ERROR:存在非法字符输入"<<endl; return 0; } } return 1;//没有非法字符 返回1 否则返回0 } int match(string s)//栈结构的括号匹配检测函数 { int i=0,top=0; char stack[50]; while(s[i]!='\0') { if(s[i]=='(') { stack[top]=s[i]; top++; }//push 左括号压入栈内 if(s[i]==')') if(stack[top-1]=='(') { int a=i+1; stack[top-1]=NULL; top--; }//把与右括号匹配的左括号弹掉 else { cout<<"ERROR:括号输入有误"<<endl; return 0;//多了右括号 括号失陪 返回非法 }//pop'(' i++; } if (top!=0) { cout<<"ERROR:括号输入有误"<<endl; return 0;//多了左括号 括号失陪 返回非法 } return 1;//返回合法 } class NUMstack//运算数栈 { public: double num[1000]; int top; void start()//初始化栈清空栈顶指针置底 { for(int i=0;i<1000;i++) num[i]=0; top=0; } void push(char a)//因为有多位数的运算因此不能一压栈就提升栈顶指针 { num[top]=num[top]*10+(a-'0'); } double pop()//弹栈函数 弹掉栈顶元素 栈顶归0 top指针下降 { top--; double number=num[top]; num[top]=0; return number; } double getTop()//取栈顶元素但不必弹栈 { return num[top-1]; } void lift()//提升top指针的函数 { top++; } }; class OPERstack//运算符栈 { public: char oper[1000]; int top; void start()//初始化函数栈清空栈底放一"="用于判定算式结束 { oper[0]='='; for(int i=1;i<1000;i++) oper[i]=NULL; top=1; } void push(char a)//与数字栈不同一压栈就可以提升指针 { oper[top]=a; top++; } char pop()//弹出计算符 用于计算 { top--; char op=oper[top]; oper[top]=NULL; return op; } char getTop()//取栈顶符号 但不弹栈 可用于判定优先级 { return oper[top-1]; } }; void calculate(string equation)//算式计算函数(关键函数) { NUMstack number;//定义运算数栈变量number OPERstack oper;//定义运算符栈变量oper number.start(); oper.start();//把两个栈初始化 int i=0,len=0,k; char p,sig; double yuan1,yuan2; while(equation[i]!='\0') { len++; i++; }//计算等式长度len if(equation[len-1]!='=') { cout<<"ERROR:未输入等号"<<endl; return;//检测有没有结束符等号"=" } int le; le=illegal_char(equation,len-1); if(le==0) return;//有非法字符 不进行后续计算 le=match(equation); if(le==0) return;//括号匹配非法 不进行后续计算 for(i=0;i<len;i++)//初步确定合法后开始计算算式 { if(equation[i]=='!')//阶乘是后缀单目运算符单独进行计算 { yuan1=number.pop();//弹出栈顶元素做阶乘 if (yuan1==0) { number.num[number.top]=0;//0的阶乘为0 压结果入栈 number.lift(); } else { number.num[number.top]=1; for(k=1;k<=yuan1;k++)//阶乘循环 number.num[number.top]=k*number.num[number.top]; number.lift();//结果入站 } } else if(equation[i]>='0'&&equation[i]<='9') { number.push(equation[i]);//压数字字符入栈 if((equation[i+1]<'0'||equation[i+1]>'9')&&equation[i+1]!='.') number.lift();//当整个多位运算数读取完毕后,运算数栈栈顶指针才能提升 } else if(equation[i]=='p') { number.num[number.top]=3.1415926536;//pi值即π 圆周率 要压入数字栈 number.lift(); i++;//pi是两个字符所以要移动扫描算式的指针往后跳一个 } else if(equation[i]=='e') { number.num[number.top]=2.718281828459;//e 自然对数底数 压入运算数栈 number.lift(); } else if(equation[i]=='.')//小数压栈代码 { int x=1; while(equation[i+x]>='0'&&equation[i+x]<='9') { number.num[number.top]+=((equation[i+x]-'0')/pow(10.0,x));//第x位小数入栈 x++; } x--; number.lift(); i=i+x; } else if(equation[i]=='(') { oper.push(equation[i]);//左括号无条件压栈 } else//数阶乘左括号判断完毕后其他运算符的分类讨论 { if(oper.top==1)//运算符栈为空运算符可以无条件入栈 { if(equation[i]=='l'&&equation[i+1]=='o') oper.push('l'); else if(equation[i]=='l'&&equation[i+1]=='n') oper.push('n');//因为log和ln都是小写字母l开头所以要分情况讨论 else oper.push(equation[i]); } else//运算符栈不为空则要进行优先级判断 { char temp1=oper.getTop();//取出栈顶符号 char temp2;//待入栈符号 if(equation[i]=='l'&&equation[i+1]=='o') temp2='l'; else if(equation[i]=='l'&&equation[i+1]=='n') temp2='n';//log与ln的再次讨论 else temp2=equation[i]; p=Precede(temp1,temp2); if(p=='<') oper.push(temp2);//栈顶符优先级较低现在待定的运算符就可以入栈了 if(p=='>'||p=='=') { char rep=p;//当栈顶符优先级不低于待入栈的符号 则运算符栈不停地弹栈 //进行运算直到低于待入栈符号为止 rep用于记录比较结果 要多次进行判断 while((rep=='>'||p=='=')&&(oper.top-1>0)) { sig=oper.pop(); yuan1=number.pop(); yuan2=number.getTop();//靠前的一个运算数只要取得不要弹出来 if(sig=='/'&&yuan1==0)//yuan1是双目运算符后面的第二运算元 { cout<<"ERROR:除数为零"<<endl; return; } if(sig=='^'&&yuan2<0&&yuan1>0&&yuan1<1&&(static_cast <int>(1/yuan1))%2==0)//对负数开偶次根号的限制 { cout<<"ERROR:负数开偶次根号"<<endl; return; } if(sig=='_'||sig=='s'||sig=='c'||sig=='t'||sig=='l'||sig=='n')//若为前缀单目运算符 { double tt; tt=S_Operate(sig,yuan1); number.num[number.top]=tt;//运算结果压回原来yuan1在栈内的位置 number.lift();//提升指针 temp1=oper.getTop(); rep=Precede(temp1,temp2);//再判优先级 } else { number.num[(number.top)-1]=D_Operate(yuan2,sig,yuan1); temp1=oper.getTop(); rep=Precede(temp1,temp2);//双目运算符的计算 } } if(equation[i]==')')//如果栈外符是右括号要把与之匹配的左括号弹出栈外 oper.pop(); else if(equation[i]=='l'&&equation[i+1]=='o') oper.push('l');//代表log的l else if((equation[i]=='l')&&(equation[i+1]=='n')) oper.push('n');//代表ln的n else oper.push(equation[i]); } } if(equation[i]=='s'||equation[i]=='c'||equation[i]=='t'||(equation[i]=='l'&&equation[i+1]=='o')) i=i+2; if(equation[i]=='l'&&equation[i+1]=='n') i++;//对于不止一个字符的运算符 sin log ln等等 要移动扫描算式的指针 往后跳一个或两个 } } if(number.num[0]==ceil(number.num[0])) cout<<equation<<number.num[0]<<endl; else cout<<equation<<fixed<<setprecision(8)<<number.num[0]<<endl;//输出结果控制精度8位小数 //调试时检查运算结束后栈内情况的代码 } void main() { system("cls"); string equation; cout<<endl<<endl<<"请输入算式,以等号结束:"<<endl; cin>>equation; calculate(equation); system("cls"); main(); }

LNK2001;LNK1120【VC6.0】

代码如下: 疯狂的小鸟 C++ #include< stdlib.h> #include<windows.h> #include< time.h> #include<conio.h> #include< iostream> #include< mmsystem.h> #include "SDL_image.h" #include "SDL_ttf.h" #include "SDL.h" using namespace std; #pragma comment(lib, "winmm.lib") #pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"") intiii=0; intscore =0; inty=0; intposi[3][2]= {{640,-300},{940,-300},{1240,-300}}; inti=0,n=3; //n为管道对数 SDL_Color textColor_1 = { 37, 134, 108 };//绿色 //SDL_Color textColor_2 = { 112, 112, 35 }; SDL_Color textColor_2 = { 255, 255, 255 }; //白色 SDL_Color textColor_3 = { 0, 88, 132 }; //白色 class Event { public: SDL_Event event; Uint8 *keystates; Event() { keystates=SDL_GetKeyState( NULL ); } }; Event thing; classData { public: int bird_y; int score; int posi[20][2]; SDL_Rect bird_1; SDL_Rect bird_2; SDL_Rect bg; SDL_Rect welcome; SDL_Rect pipe_up; SDL_Rect pipe_down; SDL_Rect bird_cls; SDL_Rect foot; SDL_Surface* load_imag(char*s) { SDL_Surface* temp; temp=IMG_Load(s); bg.x=0; bg.y=0; bg.w=640; bg.h=480; welcome.x=681; welcome.y=0; welcome.w=640; welcome.h=480; bird_1.x=17; bird_1.y=508; bird_1.w=52; bird_1.h=34; bird_2.x=461; bird_2.y=531; bird_2.w=52; bird_2.h=33; bird_cls.w=52; bird_cls.h=33; bird_cls.x=0; bird_cls.y=0; pipe_up.x=1361; pipe_up.y=11; pipe_up.w=103; pipe_up.h=410; pipe_down.x=1487; pipe_down.y=14; pipe_down.w=103; pipe_down.h=443; foot.x=0; foot.y=404; foot.w=640; foot.h=80; return temp;//SDL_DisplayFormat( temp ); } TTF_Font* load_font() { SDL_Init( SDL_INIT_EVERYTHING ); TTF_Init(); return TTF_OpenFont( "main_1.dat", 36 ); } }; Data data; class Pri { public: SDL_Surface* out; //输出 SDL_Surface* main ; //主窗口 TTF_Font *font; SDL_Rect a; //设置初始位置 SDL_Surface*bird; SDL_Rect xy; SDL_Surface*font_1; SDL_Surface*font_2; SDL_Surface*font_11; SDL_Surface*font_22; Pri() { TTF_Font *font = NULL; init();//初始化输出设备 } int init() { SDL_Init( SDL_INIT_EVERYTHING ); TTF_Init(); main= SDL_SetVideoMode( 640, 478, 32, SDL_SWSURFACE ); SDL_WM_SetCaption("Flappy bird",NULL);//标题 font=data.load_font(); out=data.load_imag("main_2.dat"); y=150; posi[0][0]=640; posi[0][1]=-300; posi[1][0]=940; posi[1][1]=-300; posi[2][0]=1240; posi[2][1]=-300; return 1; } int pipe() { } int bir(int y)//x=150 {int ii; i+=1; xy.x=150; xy.y=y; if(i<14) { xy.x=150; xy.y=y; SDL_BlitSurface(out,&data.bg,main,NULL); for(ii=0;ii<n;ii++) { xy.x=posi[ii][0]; xy.y=posi[ii][1]; SDL_BlitSurface(out,&data.pipe_down,main,&xy); xy.x=posi[ii][0]; xy.y=posi[ii][1]+600; SDL_BlitSurface(out,&data.pipe_up,main,&xy); } xy.x=150; xy.y=y; SDL_BlitSurface(out,&data.bird_1,main,&xy); xy.x=0; xy.y=404; SDL_BlitSurface(out,&data.foot,main,&xy); } else { xy.x=150; xy.y=y; SDL_BlitSurface(out,&data.bg,main,NULL); for(ii=0;ii<n;ii++) { xy.x=posi[ii][0]; xy.y=posi[ii][1]; SDL_BlitSurface(out,&data.pipe_down,main,&xy); xy.x=posi[ii][0]; xy.y=posi[ii][1]+600; SDL_BlitSurface(out,&data.pipe_up,main,&xy); } xy.x=150; xy.y=y; SDL_BlitSurface(out,&data.bird_2,main,&xy); xy.x=0; xy.y=404; SDL_BlitSurface(out,&data.foot,main,&xy); if(i>28)i=0; } return 0; } int bg() { SDL_BlitSurface(out,&data.bg,main,&xy); return 0; } int over() { int x=0,y=0,i=0; xy.x=250; xy.y=150; font_1=TTF_RenderText_Solid( font, "Game over !", textColor_3); SDL_BlitSurface( font_1 , NULL, main,& xy); SDL_Flip(main); xy.x=350; xy.y=200; font_1=TTF_RenderText_Solid( font, "Retry game", textColor_1 ); font_11=TTF_RenderText_Solid( font, "Retry game", textColor_2 ); SDL_BlitSurface( font_1 , NULL, main,& xy); xy.x=350; xy.y=280; font_2=TTF_RenderText_Solid( font, " Exit game", textColor_1 ); font_22=TTF_RenderText_Solid( font, " Exit game", textColor_2 ); SDL_BlitSurface( font_2 , NULL, main,& xy); /* xy.x=10; xy.y=440; //野指针 SDL_BlitSurface( TTF_RenderText_Solid( font, "Esc:exit game Space:to jump hekun ", textColor_1 ) , NULL, main,& xy); SDL_Flip( main ); //更新窗口 */ while(SDL_PollEvent(& thing.event ), 1) { i+=2; Sleep(1); if( thing.keystates[ SDLK_ESCAPE] )exit(0); if( thing.event.type == SDL_QUIT )// 点击了SDL关闭按钮 { exit(0); } if((x>350&&x<540)&&(y<240)&&(y>200)) { if(thing. event.type == SDL_MOUSEBUTTONDOWN) if(thing.event.button.button== SDL_BUTTON_LEFT ) { SDL_FreeSurface(font_1); SDL_FreeSurface(font_11); SDL_FreeSurface(font_22); SDL_FreeSurface(font_2); WinExec("Flappy bird.exe",NULL); exit(0); return 11; } } else { } if((x>350&&x<540)&&(y<320)&&(y>280)) //结束游戏 { if(thing. event.type == SDL_MOUSEBUTTONDOWN) if(thing.event.button.button== SDL_BUTTON_LEFT )exit(0); } if(thing. event.type == SDL_MOUSEMOTION ) { x=thing.event.motion.x; y=thing.event.motion.y; //获得鼠标坐标 if((thing.event.motion.x>350&&thing.event .motion .x<540)&&(thing.event.motion.y<240)&&(thing.event.motion.y>200)) { xy.x=350; xy.y=200; SDL_BlitSurface( font_11, NULL, main,& xy); SDL_Flip(main); } else { xy.x=350; xy.y=200; SDL_BlitSurface( font_1 , NULL, main,& xy); SDL_Flip(main); } if((thing.event.motion.x>350&&thing.event .motion .x<540)&&(thing.event.motion.y<320)&&(thing.event.motion.y>280)) { xy.x=350; xy.y=280; SDL_BlitSurface( font_22 , NULL, main,& xy); SDL_Flip(main); } else { xy.x=350; xy.y=280; SDL_BlitSurface( font_2 , NULL, main,& xy); SDL_Flip(main); } } } return 0; } intwelcome() { intx=0,y=0,i=0; SDL_BlitSurface(out,&data.welcome,main,NULL); bird=out; xy.x=350; xy.y=200; font_1=TTF_RenderText_Solid( font, "Start game", textColor_1 ); font_11=TTF_RenderText_Solid( font, "Start game", textColor_2 ); SDL_BlitSurface( font_1 , NULL, main,& xy); xy.x=350; xy.y=280; font_2=TTF_RenderText_Solid( font, " Exit game", textColor_1 ); font_22=TTF_RenderText_Solid( font, " Exit game", textColor_2 ); SDL_BlitSurface( font_2 , NULL, main,& xy); xy.x=10; xy.y=440; //野指针 SDL_BlitSurface( TTF_RenderText_Solid( font, "Esc:exit game Space:to jump hekun ", textColor_1 ) , NULL, main,& xy); SDL_Flip( main ); //更新窗口 while(SDL_PollEvent(& thing.event ), 1) { i+=2; Sleep(1); if( thing.keystates[ SDLK_ESCAPE] )exit(0); if( thing.event.type == SDL_QUIT )// 点击了SDL关闭按钮 { exit(0); } if((x>350&&x<540)&&(y<240)&&(y>200)) { if(thing. event.type == SDL_MOUSEBUTTONDOWN) if(thing.event.button.button== SDL_BUTTON_LEFT ) { SDL_FreeSurface(font_1); SDL_FreeSurface(font_11); SDL_FreeSurface(font_22); SDL_FreeSurface(font_2); return 0; } } else { } if((x>350&&x<540)&&(y<320)&&(y>280)) //结束游戏 { if(thing. event.type == SDL_MOUSEBUTTONDOWN) if(thing.event.button.button== SDL_BUTTON_LEFT )exit(0); } if(thing. event.type == SDL_MOUSEMOTION ) { x=thing.event.motion.x; y=thing.event.motion.y; //获得鼠标坐标 if((thing.event.motion.x>350&&thing.event .motion .x<540)&&(thing.event.motion.y<240)&&(thing.event.motion.y>200)) { xy.x=350; xy.y=200; SDL_BlitSurface( font_11, NULL, main,& xy); SDL_Flip(main); } else { xy.x=350; xy.y=200; SDL_BlitSurface( font_1 , NULL, main,& xy); SDL_Flip(main); } if((thing.event.motion.x>350&&thing.event .motion .x<540)&&(thing.event.motion.y<320)&&(thing.event.motion.y>280)) { xy.x=350; xy.y=280; SDL_BlitSurface( font_22 , NULL, main,& xy); SDL_Flip(main); } else { xy.x=350; xy.y=280; SDL_BlitSurface( font_2 , NULL, main,& xy); SDL_Flip(main); } } if(i==400) { xy.x=150; xy.y=250; SDL_BlitSurface(bird,&data.bird_1,main,&xy); SDL_Flip(main); } if(i==800) { xy.x=150; xy.y=250; SDL_BlitSurface(bird,&data.bird_2,main,&xy); i=0; SDL_Flip(main); } } return 0; } }; Pri pri; int game_judge() {int i=0; if(y>370||y<-10) { if(pri.over()==11)return12; } for(i=0;i<3;i++) { if(posi[i][0]<202&& posi[i][0]>50) { if(y<posi[i][1]+ 420 ||y>posi[i][1]+570) {if(pri.over()==11)return12;} } } return0; } int game_loop() { y=150,i=0; int ii=0,iii=0; SDL_Surface *font; pri.bg(); chars[50]; Uint32 start = 0; sprintf(s," FPS:%d\t\t\t\t\t\t\t\tScore:%d",1000/(SDL_GetTicks()-start),score); intq=0; while(SDL_PollEvent(& thing.event ), 1) { start = SDL_GetTicks(); i++; Sleep(1); SDL_Flip(pri.main); y+=4; if(y>430)y=100; if(thing.event.button.state==SDL_PRESSED)y-=20; if( thing.keystates[ SDLK_SPACE] )y-=20; if( thing.keystates[ SDLK_ESCAPE] )exit(0); if( thing.event.type == SDL_QUIT )// 点击了SDL关闭按钮 { exit(0); } if(game_judge()==12)return0; pri.bir(y); //显示 每秒循环的次数 ii++; if(ii>20) { sprintf(s," FPS:%d\t\t\t\t\t\t\t\tScore:%d",1000/(SDL_GetTicks()-start)+rand()%5,score); ii=0; } font=TTF_RenderText_Solid( pri.font, s, textColor_2 ); SDL_BlitSurface(font , NULL,pri. main, NULL); SDL_Flip(pri.main); SDL_FreeSurface(font); posi[0][0]-=2; posi[1][0]-=2; posi[2][0]-=2; if(posi[0][0]<=(-110)) {posi[0][0]=posi[2][0]+300;posi[0][1]=-(rand()%180)-220;} if(posi[1][0]<=(-110)) {posi[1][0]=posi[0][0]+300;posi[1][1]=-(rand()%180)-220;} if(posi[2][0]<=(-110)) {posi[2][0]=posi[1][0]+300;posi[2][1]=-(rand()%180)-220;} iii++; if(iii>50) for(iii=0;iii<3;iii++) { if(posi[iii][0]<50); score++; iii=0; break; } } return 0; } int main(int argc, char* argv[]) { while(1) { pri.init();//初始化输出设备 pri.welcome(); game_loop(); } return0; } 编译没有报错,连接显示MSUCRTD.lib(crtexe.obj):error LNK2001:unresolved external symbol_main Debug:fatal error LNK1120:14 unresolved externals. 14个错误都是这种样式: error LNK2001:unresolved external symbol _TTF_Init 工程是win32 application 设置里面连接都改成了/subsystem:windows C/C++的预处理器也改成了windows,预编译头文件全部选择不使用预补偿页眉 常规里面选择了使用MFC作为共享的DLL 以上都是我百度的方法,全部试过 也没有用。所以只好来麻烦各位大神了

在VC6.0上是可以完整运行的但是在vs2012各种报错,求大神进来帮忙修改一下

#include<stdio.h> #include<stdlib.h> #include<string.h> #include<ctype.h> #define MAXWORD 30 /*单词最多字符数*/ #define MAXARRAY 2000 /*文件最多单词总数*/ #define MAXLINE 80 /*每次最多读取MAXLINE-1个字符*/ struct node { char word [MAXWORD]; int count; }; /*函数声明*/ void GetWord(char *p, struct node *wArry); void AddArray(char *w, struct node *p); void PritArray(struct node *p); /*主程序*/ int main (int argc, char argv[]) { int i; FILE *fp; struct node arrayWord[MAXARRAY]; char line[MAXLINE]; /*数组初始化*/ for(i = 0; i < MAXARRAY ;i++ ) { arrayWord[i].count = 0; arrayWord[i].word = '\0'; /*检查命令行参数个数*/ if(argc != 2) { printf("Usage :countWords Filename\n"); exit(1); } /*打开文件*/ if (fp = fopen(argv[1], "r")) { printf("countword:can't open %s\n",argv[1]); exit(1); } /*统计单词*/ while (fgets(line,MAXLINE, fp) != NULL) { GetWord(line, arrayWord); } /*显示统计结果*/ PritArray(arrayWord); } /*提取单词*/ void GetWord(char *p, struct node *wArry); { int n; char word[MAXWORD]; char *q, *w; while (isspace(*p)) { p++; } while (*p != '\0') { n = 0;/*单词字符个数,初始化为0*/ if (isspace(*p) && isspace (*(p-1)))/*单词的首个字母*/ { q = p; /*记录单词的开始位置*/ while (isspace(*p) && n < MAXWORD) { p++; n++; } /*单词以空白字符结尾*/ if(isspace(*p) || *p == '\0') { w = word; while (q < p) { /*复制单词到word[]*/ *w++ = *p++ ; } *w = '\0'; /*将单词添加到arryWord[MAXARRAY]*/ AddArray(word, wArray); } } if (*p != '\0') { p++; } } } /*统计单词*/ void AddArray(char *w, struct node *p); { int i; for (int i = 0; i < MAXARRAY; i++, p++) { if (strcmp(p ->count, w) == 0) { /*单词已经存在*/ p ->count++; break; }else if (p ->count ==0) { /*单词不存在*/ strcpy(p -> word, w); p ->count = 1; break; } } } /*显示统计结果*/ void PritArray(struct node *p); { while (p ->count > 0) { printf("%4d %s\n",p ->count,p->word); p++; } } 首先是定义数组那里 arrayWord[i].word = '\0';提示表达式必须是可修改的左值 /*打开文件*/哪里 error C2664: “fopen”: 不能将参数 1 从“char”转换为“const char *” 最后是定义函数括号里的形参,在函数里面会报错举个例子: void AddArray(char *w, struct node *p);这个自定义函数 如果我下面这样写 if (strcmp(p ->count, w) == 0),这里面的w就会报错,提示未定义标识符,次啊面的函数也是这么个情况,请问昨晚那么晚改???

链表程序vc6.0可以运行但vs不能运行

应该是没有给p赋初值的原因,vc能通过但vs就不行 /#include<stdio.h> /#include<stdlib.h> //链表的建立与输出 struct node//定义结点的类型 { int num, score; node* link; }; void main() { node* creat(int n);//函数原型声明 void print(node * h);//函数原型声明 node* head = 0;//定义链头指针并初始化 head = creat(5);//调用creat函数创建链表 print(head);//调用print函数输出链表 } node* creat(int n) { node* h = 0, *p, * q; int i; for (i = 1; i <= n; i++) { p=q = (node*)malloc(sizeof(node));//分配一个结点空间 scanf_s("%d%d", &q->num, &q->score);//输入新结点的值 q->link = 0;//新结点的指针域置0 if (h == 0) h = q;//第一个结点作为链头结点 else p->link = q;//新结点添加到链表的末尾 p = q; } return h;//返回链头指针 } void print(node* h)//链表输出函数的定义 { while (h)//当指针h非空时输出h所指结点的值 { printf("num=%d\tscore=%d\n", h->num, h->score); h = h->link;//使h指向下一个结点 } }

在VC6.0上面运行结果正确,但是VS2015结果错误(是结果错误不是程序报错,oj上也已经AC)

#include<stdio.h>//在VC6.0上可以运行,但是在VS2015上面是死循环,头疼却AC #include<string.h> #include<stdlib.h> int main() { char a[100]; int i, j, k, n, l; while (scanf_s("%d", &n) != EOF) { for (i = 0; i < n; i++)//此处的for是一个案例,所以小括号要包含后面程序 { scanf_s("%s", a); l = strlen(a); k = 0; for (j = 0; j < l; j++) { if (a[j] != a[l - j - 1]) k++; } if (k == 0) printf("yes\n"); else printf("no\n");system("pause"); } } }

同样代码VC6.0结果正确,GCC编译运行结果不正确,原因是什么呢?谢谢!

#include <stdio.h> int main() { char deno[1000]={'\0'},num,i=0,remain=0; scanf("%s %d",deno,&num); //获取被除数、除数 if(!num) return (-1); while(deno[i]!='\0') deno[i++]-='0'; //转换成数字 deno[i]='#'; //结束标志 i=0; while(deno[i]!='#') { deno[i]+=remain; //低位+高位余数 remain=10*(deno[i]%num); //高位余数 deno[i]=deno[i]/num+'0'; //商的ASCII码 i++; } deno[i]='\0'; //串尾 remain/=10; //最后余数 if(deno[0]=='0'&&deno[1]!='\0') //高位0不显示 printf("%s %d",&deno[1],remain); else printf("%s %d",deno,remain); return 0; } VC++6.0下运行结果: ![图片说明](https://img-ask.csdn.net/upload/201603/17/1458193647_221026.png) ![图片说明](https://img-ask.csdn.net/upload/201603/17/1458193667_975354.png) ![图片说明](https://img-ask.csdn.net/upload/201603/17/1458193692_27673.png) GCC编译后运行结果: ![图片说明](https://img-ask.csdn.net/upload/201603/17/1458193715_237538.png)

在VC6.0上面运行结果正确,但是VS2015结果错误(是结果错误不是程序报错,oj上也已经AC)

#include<stdio.h> #include<string.h> #include<stdlib.h> int main() { char a[100]; int i, j, k, n, l; while (scanf_s("%d", &n) != EOF) { for (i = 0; i < n; i++) { scanf_s("%s", a); l = strlen(a); k = 0; for (j = 0; j < l; j++) { if (a[j] != a[l - j - 1]) k++; } if (k == 0) printf("yes\n"); else printf("no\n");system("pause"); } } }

问各位一下,VC6.0会因为代码执行的时间过长,而终止运行

如下程序: #include<stdlib.h> #include<iostream.h> struct PolyNode { float coef; int exp; PolyNode * next; }; //template<typename T> class PolyLinkList { public: PolyLinkList(float a[],int n=0); ~PolyLinkList(); void ShowList(); void PolyAdd(PolyLinkList & LB); private: PolyNode * head; }; //--------------------------------------------------------------------------- //template<typename T> PolyLinkList::PolyLinkList(float a[],int n) { int i=0; PolyNode * q=head; for(i=0;i<n;i++) { PolyNode * s=new PolyNode; s->coef=a[i]; s->exp=i; q->next=s; q=q->next; } } //template<typename T> PolyLinkList::~PolyLinkList() { PolyNode * p=head; while(p->next) { PolyNode * q=p; p=p->next; delete q; } } //template<typename T> void PolyLinkList::ShowList() { PolyNode * p=head; while(p->next!=NULL) { cout<<p->next->coef<<"*E"<<p->next->exp; if(p->next->next!=NULL) cout<<"+"; //cout<<endl; p=p->next; } cout<<endl; } //template<typename T> void PolyLinkList::PolyAdd(PolyLinkList & LB) { float sum; PolyNode * pa,* pb,* qa,* qb; pa=head; qa=pa->next; pb=LB.head; qb=pb->next; while(qa!=NULL&&qb!=NULL) { if(qa->exp<qb->exp) { pa=qa; qa=qa->next; } else if(qa->exp>qb->exp) { pb->next=qb->next; qb->next=qa; pa->next=qb; pa=qb; qb=pb->next; } else { sum=qa->coef+qb->coef; if(sum==0) { pa->next=qa->next; delete qa; pb->next=qb->next; delete qb; qb=pb->next; } else { qa->coef=sum; pa=qa; qa=qa->next; pb->next=qb->next; delete qb; qb=pb->next; } } } if(qb!=NULL) qa->next=qb; } /*void PolyLinkList::ShowList() { PolyNode * p=head; while(p->next) { cout<<p->next->coef<<"*E"<<p->next->exp; if(!(p->next->next)) cout<<"+"; } }*/ //------------------------------------------------------------------------------------- void main() { float a[5]={1.0,2.0,3.0,4.0,5.0}; PolyLinkList str(a,5); str.ShowList(); float b[5]={6.0,7.0,8.0,9.0,0}; PolyLinkList str1(b,5); str.PolyAdd(str1); str.ShowList(); system("pause"); }

vc6.0 中extern使用时遇到的2个疑问,还望诸位帮忙看下,多谢

我在文件1CTestHello.cpp 声明了 extern void delete_string(char a[],char b[],char standard); 再调用文件2 file2.c中的delete_string(a,b,Standard);函数; 发现2个问题: 问题1;用extern实验发现必须用include,但查找资料,没有说这两个有必然关联。请问到底有没有必然关联?下面是实验: 如果文件1中不#include "file2.c",编译没问题,链接出错,提示: CTestHello.obj : error LNK2001: unresolved external symbol "void __cdecl delete_string(char * const,char * const,char)" (?delete_string@@YAXQAD0D@Z) Debug/TestHello.exe : fatal error LNK1120: 1 unresolved externals 执行 link.exe 时出错. TestHello.exe - 1 error(s), 0 warning(s) 如果文件1中#include "file2.c",编译没问题,链接没问题,一切正常; 示例如下: 文件1:CTestHello.cpp #define PI 3.14 #include <stdio.h> #include <stdlib.h> #include <string.h> ///#include "file2.c" void main() { //015-1-2字符串查找删除,多文件: char a[]="abcdccdefc"; int len=strlen(a); char b[10]; char Standard='c'; extern void delete_string(char a[],char b[],char standard); delete_string(a,b,Standard); //void stringdel(char a[],char b[],char Standard); //stringdel(a,b,Standard); printf("字符串b:%s\n",b); for(int t=0;b[t]!='\0';t++) { printf("第i个元素:%c\n",b[t]); } } 文件二:file2.c #include <stdio.h> extern void delete_string(char a[],char b[],char Standard) { int k=0;//a和b由于a有Standard,导致b下标相差的 int j=0; int n=0; int i=0; for(;a[i]!='\0';i++) { if(a[i]!=Standard) { j=i-k; b[j]=a[i]; n++; } else { k++; } } b[n]='\0'; } 问题二:如果外部文件中的extern函数名,和本文件中的函数名重名,编译提示函数重定义,感觉不应该有这个提示啊? 编译提示: --------------------Configuration: TestHello - Win32 Debug-------------------- Compiling... CTestHello.cpp d:\code\c\vc\testhello\ctesthello.cpp(321) : error C2375: 'stringdel' : redefinition; different linkage d:\code\c\vc\testhello\file2.c(2) : see declaration of 'stringdel' 执行 cl.exe 时出错. CTestHello.obj - 1 error(s), 0 warning(s) 实例如下: 文件1:CTestHello.cpp #define PI 3.14 #include <stdio.h> #include <stdlib.h> #include <string.h> ///#include "file2.c" void main() { //015-1-2字符串查找删除,多文件: char a[]="abcdccdefc"; int len=strlen(a); char b[10]; char Standard='c'; extern void stringdel(char a[],char b[],char standard); stringdel(a,b,Standard); //void stringdel(char a[],char b[],char Standard); //stringdel(a,b,Standard); printf("字符串b:%s\n",b); for(int t=0;b[t]!='\0';t++) { printf("第i个元素:%c\n",b[t]); } } static void stringdel(char a[],char b[],char Standard) { int k=0;//a和b由于a有Standard,导致b下标相差的 int j=0; int n=0; for(int i=0;a[i]!='\0';i++) { if(a[i]!=Standard) { j=i-k; b[j]=a[i]; n++; } else { k++; } } b[n]='\0'; } 文件二:file2.c #include <stdio.h> extern void stringdel(char a[],char b[],char Standard) { int k=0;//a和b由于a有Standard,导致b下标相差的 int j=0; int n=0; int i=0; for(;a[i]!='\0';i++) { if(a[i]!=Standard) { j=i-k; b[j]=a[i]; n++; } else { k++; } } b[n]='\0'; }

vc6.0模拟时钟问题,两个循环无法同时运行

#include "graphics.h" #include "conio.h" #include "time.h" #include "math.h" int main(){ int x0=400,y0=200; int x1=0,y1=0; int h=0; int m=0; int r=90; int b=0,c=0,d=0,e=0; char T[]="00:00:00"; char S[]="0123456789"; double pi=3.14159; initgraph(800,600); for(int i=0;i<=360;i+=6){ cleardevice(); setlinecolor(YELLOW); circle(x0,y0,r+18); setlinecolor(CYAN); circle(x0,y0,r+10); x1=(int)(r*cos((i-90)*pi/180)+x0); y1=(int)(r*sin((i-90)*pi/180)+y0); line(x0,y0,x1,y1); if(i==360){ m+=6;i=0; } x1=(int)((r-20)*cos((m-90)*pi/180)+x0); y1=(int)((r-20)*sin((m-90)*pi/180)+y0); line(x0,y0,x1,y1); if(m==360){ h+=30;m=0; } x1=(int)((r-30)*cos((h-90)*pi/180)+x0); y1=(int)((r-30)*sin((h-90)*pi/180)+y0); line(x0,y0,x1,y1); Sleep(1000); for(int a=0;a<60;a++){ if(a<10){ T[6]='0'; T[7]=S[a]; }else{ b=a%10; c=a/10; T[6]=S[c]; T[7]=S[b]; } if(d<10){ T[3]='0'; T[4]=S[d]; }else{ b=d%10; c=d/10; T[3]=S[c]; T[4]=S[b]; } if(e<10){ T[0]='0'; T[1]=S[e]; }else{ b=e%10; c=e/10; T[0]=S[c]; T[1]=S[b]; } outtextxy(400,500,T); Sleep(1000); if(a>=59){ a=-1; d++; } if(d>60){ d=0; e++; } if(e>=24){ e=0; } } } if(i>360){ i=0; } getch(); closegraph(); return 0; } 如何才能让 如何才能让电子时钟和时钟的指针同时动起来 谢谢 我用的VC6.0打了easyx的插件![图片说明](https://img-ask.csdn.net/upload/201512/23/1450851192_434198.jpg)

VC6.0 小学生四则运算

程序调试没有错误,就是运行不了 #include<iostream> #include<cstdlib> #include<string> #include <fstream> #include <conio.h> #include<iomanip> #include<ctime> using namespace std; #define MaxSize 100 struct stud { string usename;//文件记录的用户名 string code;//文件记录的密码 int sumnum;//总题数 double percent;//正确率 string end; }student[100];//stud student[100]; string rightusename,rightcode; int rightsumnum; double rightpercent; int n2;//文件中记录的学生所在第几个位置 int init1() { cout<<"小学生四则运算考试模拟系统"<<endl; cout<<" | "<<endl; cout<<" | "<<endl; cout<<" 1.登陆 | "<<endl; cout<<" | "<<endl; cout<<"------------+-------------"<<endl; cout<<" | "<<endl; cout<<" 2.注册 | "<<endl; cout<<" | "<<endl; cout<<" | "<<endl; cout<<"请选择(输入数字):"<<endl; return 1; } int calculate() { string usename; string code; ifstream fp2; fp2.open ("data.txt"); fp2.seekg (0, ios::end); int last = fp2.tellg(); // cout<<"个数"<<last; // cout<<"模版"<<sizeof(student)/100; int n=last/(sizeof(student)/100-7); // cout<<"对象个数:"<<n<<"\n"; //查询文件中对象的个数 ifstream fp3("data.txt"); int i=0; int sumnum; double percent; string end; while(i<n) { fp3>>usename>>code>>sumnum>>percent>>end; student[i].usename=usename; student[i].code=code; i++; } return n; } bool checkout()//登陆验证 { string usename; string code; cout<<"please input your usename:"; cin>>usename; int count=calculate(); bool findname=false; for (int i=0;i<count;i++) { if (student[i].usename==usename) { findname=true; rightusename=usename; cout<<"Name OK!\n"; int j=0; char str[10]="\0"; cout<<"please input your password:"; while (1) { str[j]= getch(); if (str[j++]=='\r')break; cout<<"*"; } for(int s = 0;s<j-1;s++) code += str[s]; bool findcode=false; if (student[i].code==code) { cout<<"\nLogin successfully!"<<endl; findcode=true; n2=i; rightcode=code; system("pause"); return true; } if (!findcode) { cout<<"\nPassword is not correct!"<<endl; system("pause"); return false; } } } if (!findname) { cout<<"Usename is not existed!"<<endl; system("pause"); return false; } getch(); } void Register()//注册 { string code,usename; double percent=0; int sumnum=0; cout<<"请输入你所确定用户名:"; cin>>usename; bool findname = true; while(findname){ findname = false; int count = calculate(); for (int i=0;i < count;i++) { if (!student[i].usename.compare(usename) ) {findname=true;} } if (findname) { cout<<"******************************"<<endl; cout<<"* 用户名已存在! *"<<endl; cout<<"* 请重新输入你的用户名! *"<<endl; cout<<"******************************"<<endl; system("pause"); system("cls"); cout<<"你所确定的用户名:"; cin>>usename; } } int i=0; char str[10]="\0"; cout<<"请输入你所确定的密码:"; while (1) { str[i]= getch(); if (str[i++]=='\r')break; cout<<"*"; } for(int s = 0;s<i-1;s++) code += str[s]; // cout<<"\n请分别输入你所确定密码:"<<code<<endl; string end="end"; int number=0; ofstream fp("data.txt",ios::app); fp<<setw(16)<<usename<<"\n"<<setw(16)<<code<<"\n" <<setw(4)<<sumnum<<"\n"<<setw(8)<<percent<<"\n"<<end<<endl; cout<<"\n"<<"\t"<<" 注册成功!"<<endl; cout<<"*************************************"<<endl; printf("请重新登陆,退出请按E,继续请按其他键!"); char E; scanf("%s",&E); if(E=='E')exit(0); } struct { char ch; int pri; } //设定运算符优先级,ch运算符,pri优先级 lpri[]={{'=',0},{'(',1},{'*',5},{'/',5},{'+',3}, {'-',3},{')',6}}, rpri[]={{'=',0},{'(',6},{'*',4},{'/',4},{'+',2}, {'-',2},{')',1}}; int leftpri(char op) //求左运算符op的优先级 { int i; for (i=0;i<7;i++) if (lpri[i].ch==op) return lpri[i].pri; } int rightpri(char op) //求右运算符op的优先级 { int i; for (i=0;i<7;i++) if (rpri[i].ch==op) return rpri[i].pri; } bool InOp(char ch) //判断ch是否为运算符 { if (ch=='(' || ch==')' || ch=='+' || ch=='-' || ch=='*' || ch=='/') return true; else return false; } int Precede(char op1,char op2) //op1和op2运算符优先级的比较结果 { if (leftpri(op1)==rightpri(op2)) return 0; else if (leftpri(op1)<rightpri(op2)) return -1; else return 1; } void trans(char *exp,char postexp[]) //将算术表达式exp转换成后缀表达式postexp { struct { char data[MaxSize]; //存放运算符 int top; //栈指针 } op; //定义运算符栈 int i=0; //i作为postexp的下标 op.top=-1; op.top++; //将'='进栈 op.data[op.top]='='; while (*exp!='\0') //exp表达式未扫描完时循环 { if (!InOp(*exp)) //为数字字符的情况 { while (*exp>='0' && *exp<='9') //判定为数字 { postexp[i++]=*exp; exp++; } postexp[i++]='#'; //用#标识一个数值串结束 } else //为运算符的情况 switch(Precede(op.data[op.top],*exp)) { case -1: //栈顶运算符的优先级低:进栈 op.top++;op.data[op.top]=*exp; exp++; //继续扫描其他字符 break; case 0: //只有括号满足这种情况 op.top--; //将(退栈 exp++; //继续扫描其他字符 break; case 1: //退栈并输出到postexp中 postexp[i++]=op.data[op.top]; op.top--; break; } } //while (*exp!='\0') while (op.data[op.top]!='=') //此时exp扫描完毕,退栈到'='为止 { postexp[i++]=op.data[op.top]; op.top--; } postexp[i]='\0'; //给postexp表达式添加结束标识 } float compvalue(char exp[]) //计算后缀表达式的值 { struct { float data[MaxSize]; //存放数值 int top; //栈指针 } st; //定义数值栈 float d; char ch; int t=0; //t作为exp的下标 st.top=-1; ch=exp[t];t++; while (ch!='\0') //exp字符串未扫描完时循环 { switch (ch) { case'+':st.data[st.top-1]= st.data[st.top-1]+st.data[st.top]; st.top--;break; case '-':st.data[st.top-1]= st.data[st.top-1]-st.data[st.top]; st.top--;break; case '*':st.data[st.top-1]= st.data[st.top-1]*st.data[st.top]; st.top--;break; case '/': if (st.data[st.top]!=0) st.data[st.top-1]= st.data[st.top-1]/st.data[st.top]; else { cout<<"\n"<<"\t"<<"除零错误!"<<endl; exit(0); //异常退出 } st.top--;break; default: d=0; //将数字字符转换成数值存放到d中 while (ch>='0' && ch<='9') //为数字字符 { d=10*d+ch-'0'; ch=exp[t];t++; } st.top++; st.data[st.top]=d; } ch=exp[t];t++; } return st.data[st.top]; } void test() { char algtype[10] ;//计算类型 int i,j,t,//for的循环控制变量 points = 0;//成绩 string usename,code,end; srand((unsigned )time(NULL)); int n=rand()%6+5,//题目的个数,为5到10个 num[MaxSize][MaxSize];//操作数 char op[]={'+','-','*','/'}; cout<<"---------------------------------小学生算法运算测评-----------------------------"; cout<<"现在开始计算:"<<endl<<endl; for(i=0;i<n;++i) { cout<<"第"<<i+1<<"道题:"<<endl; srand((unsigned )time(NULL)); int m=rand()%4+2;//每道题中数字的个数,为2到5个 for(j=0;j<m;++j) { num[i][j] = rand() % 9+1; //产生的随机整数 algtype[j] = rand() % 4; } char string[MaxSize];//把符号数组和数字数组组合在一个字符串里 for(t=0,j=0;t<2*m-2;++t) { string[t]=num[i][j]+'0'; t++; string[t]=op[algtype[j]]; j++; } string[2*m-2]=num[i][m-1]+'0'; string[2*m-1]='\0'; //插入括号 int t=rand() % 5, r=rand() % 5,//r,t都是小于m的随机数 min,max,a;//a为字符串的长度 while(t==r||t>=m||r>= m) { r=rand()%5; t=rand() % 5; } min=t>r?r:t;//min为r,t较小的数 max=t>r?t:r;//max为t,r较大的数 if(min==0&&max==m-1); else { for(a=2*m-1;a>2*min;a--) string[a]=string[a-1]; string[2*min]='('; for(a=2*m;a>2*max+2;a--) string[a]=string[a-1]; string[2*max+2]=')'; string[2*m+1]='\0'; } //输出字符串 int d=0; while(string[d]!='\0') cout<<string[d++]; cout<<"= ?"<<"\n"<<"\t"<<"请输入答案:"; char answer[4]; //学生回答 cin>>answer; char postexp[MaxSize]; trans(string,postexp);//求得正确的答案 int value= compvalue(postexp);//value放的是正确的结果程序的计算结果 int i1= 0; int totle=0; bool fuhao = false; if(answer[0] == '-') {fuhao = true;i1++;} for(;answer[i1]!='\0';i1++) { totle=totle*10+answer[i1]-'0'; } if(fuhao) {totle = -totle;} if(totle == value) { cout<<"\t"<<"恭喜你,答案是对的!"<<endl; points++; } else { cout<<"\t"<<"抱歉,你做错了!"; cout<<"\t"<<"正确的答案是:"<<value<<endl; } int sumnum; double percent; char yesORno ; //回答是否继续 if(i<n-1) { cout<<"\t"<<"是否继续?y/n"<<"\t"; cin>>yesORno; if(yesORno =='y') cout<<"~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"<<endl; else { cout<<"~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"<<endl; cout<<"你已终止答题!"<<endl; cout<<"你所答的题目总数为:"<<i+1<<"\t"; cout<<"你目前答对的题目数:"<<points<<"\t"; cout<<"\n"<<"你答题的正确率是:"<<setprecision(3)<<float(points)/float(i+1)*100<<"%"<<endl; rightsumnum=i+1; rightpercent=float(points)/float(i+1)*100; i = n; } } if(i==n-1) { cout<<"~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"<<endl; cout<<"你已完成所有的题目!"<<endl; cout<<"你所答的题目总数为:"<<i+1<<"\t"; cout<<"你目前答对的题目数:"<<points<<"\t"; cout<<"你答题的正确率是:"<<setprecision(3)<<float(points)/float(i+1)*100<<"%"<<endl; rightsumnum=i+1; rightpercent=float(points)/float(i+1)*100; } int location=n2*(sizeof(student)/100-7); fstream inoutfile("data.txt"); inoutfile.seekp(location); inoutfile<<setw(16)<<rightusename<<"\n"<<setw(16)<<rightcode<<"\n" <<setw(4)<<rightsumnum<<"\n"<<setw(8)<<rightpercent<<"\n"<<"end"<<endl; inoutfile.close (); } } int seegrade() { string end; system("cls"); int location=n2*(sizeof(student)/100-7); ifstream infile("data.txt"); infile.seekg(location); infile>>rightusename>>rightcode>>rightsumnum>>rightpercent>>end; int yes=rightpercent/100*rightsumnum; cout<<" \1\1\1\1 尊敬的"<<rightusename<<" \1\1\1\1"<<endl; cout<<"****************************************************"<<endl; cout<<"*您的上一次答题情况 *"<<endl; cout<<"*你所答题的个数为:"<<rightsumnum<<" *"<<endl; cout<<"*你答对的题目数为:"<<yes<<" *"<<endl; cout<<"*你答题的正确率为:"<<rightpercent<<"%"<<" *"<<endl; cout<<"****************************************************"<<endl; infile.close (); return 1; } int init2() { system("cls"); cout<<"小学生四则运算考试模拟系统"<<endl; cout<<" | "<<endl; cout<<" | "<<endl; cout<<" 1.开始答题| "<<endl; cout<<" | "<<endl; cout<<"------------+-------------"<<endl; cout<<" | "<<endl; cout<<" 2.查看分数| "<<endl; cout<<" | "<<endl; cout<<"------------+-------------"<<endl; cout<<" | "<<endl; cout<<" 3.退出 | "<<endl; cout<<" | "<<endl; cout<<" | "<<endl; cout<<"请选择(输入数字):"<<endl; return 1; } int main() { while(1) { int i; init1(); i = getch(); if(i=='1') system("cls"); else if(i='2'){system("cls");Register();system("cls");cout<<"请重新登录!"<<endl; } if(checkout()) { while(1) { init2(); int i = getch(); fflush(stdin);//清除缓冲区 if(i == '1') { system("cls"); test(); system("pause"); } else if(i == '2') {seegrade();system("pause");} else if(i == '3') break; } system("cls"); cout<<"感谢您的使用!"<<endl; system("pause"); } system("cls"); } return(0); } 请各位大神帮一下忙,不胜感激!

请问一下这个c程序有什么问题

题目:有n=3个结构体变量,内含学生学号,姓名和3门课程的成绩。要求输出平均成绩最高的学生的信息。 ``` #include <stdio.h> #define n 3 struct student {long int number; char name[20]; float s1,s2,s3; float average; }; int main() {void input(struct student *p); struct student max(struct student *p); void print(struct student p); struct student stu[n],*p=stu; input(p); print(max(p)); return 0; } void input(struct student *p) {int i; for(i=0;i<n;i++) {printf("enter student%d's number,name,3 scores:",i+1); scanf("%ld%s%f%f%f",&*(p+i).number,*(p+i).name,&*(p+i).s1,&*(p+i).s2,&*(p+i).s3); *(p+i).average=(*(p+i).s1+*(p+i).s2+*(p+i).s3)/3.0; } } struct student max(struct student *p) {int i,max; max=0; for(i=1;i<n;i++) if(*(p+max).average<*(p+i).average) max=i; return *(p+max); } void print(struct student p) { printf("number=&ld,name=%s,score1=%f,score2=%f,score3=%f",p.number,p.name,p.s1,p.s2,p.s3); } ``` --------------------Configuration: 6 - Win32 Debug-------------------- Compiling... 66.cpp D:\vc 6.0\Microsoft Visual Studio\MyProjects\6\66.cpp(22) : error C2228: left of '.number' must have class/struct/union type D:\vc 6.0\Microsoft Visual Studio\MyProjects\6\66.cpp(22) : error C2228: left of '.name' must have class/struct/union type D:\vc 6.0\Microsoft Visual Studio\MyProjects\6\66.cpp(22) : error C2228: left of '.s1' must have class/struct/union type D:\vc 6.0\Microsoft Visual Studio\MyProjects\6\66.cpp(22) : error C2228: left of '.s2' must have class/struct/union type D:\vc 6.0\Microsoft Visual Studio\MyProjects\6\66.cpp(22) : error C2228: left of '.s3' must have class/struct/union type D:\vc 6.0\Microsoft Visual Studio\MyProjects\6\66.cpp(23) : error C2228: left of '.average' must have class/struct/union type D:\vc 6.0\Microsoft Visual Studio\MyProjects\6\66.cpp(23) : error C2228: left of '.s1' must have class/struct/union type D:\vc 6.0\Microsoft Visual Studio\MyProjects\6\66.cpp(23) : error C2228: left of '.s2' must have class/struct/union type D:\vc 6.0\Microsoft Visual Studio\MyProjects\6\66.cpp(23) : error C2228: left of '.s3' must have class/struct/union type D:\vc 6.0\Microsoft Visual Studio\MyProjects\6\66.cpp(31) : error C2228: left of '.average' must have class/struct/union type D:\vc 6.0\Microsoft Visual Studio\MyProjects\6\66.cpp(31) : error C2228: left of '.average' must have class/struct/union type 执行 cl.exe 时出错.

c++运算符重载vs2015中报错,而用vc6.0不会报错

![图片说明](https://img-ask.csdn.net/upload/201703/24/1490335431_135693.png) #include "stdafx.h" #include<iostream> #include<cassert> using namespace std; template<typename T>class stack { int top; T *elements; int maxsize; public: stack(int = 20); ~stack() { delete[]elements; } void push(const T&x); T pop(); T getelem(int i); void makeempty() { top = -1; } bool isempty()const { return top == -1; } bool isfull()const { return top == maxsize - 1; } friend ostream &operator<<(ostream&, const stack<T>&);//T必不可少 }; template<typename T>stack<T>::stack(int max) { maxsize = max; top = -1; elements = new T[maxsize]; assert(elements != 0); } template<typename T> ostream& operator<<(ostream& s, const stack<T>& s1) {//T必不可少 for (int i = 0; i <= s1.top; i++) s << s1.elements[i] << ' '; s << endl; return s; } template<typename T>void stack<T>::push(const T&data) { assert(!isfull()); elements[++top] = data; } template<typename T>T stack<T>::pop() { assert(!isempty()); return elements[top--]; } template<typename T>T stack<T>::getelem(int i) { assert(i <= top&&i >= 0); return elements[i]; } void main() { stack<int> s; s.push(1); cout << s << endl; }

vc++6.0中代码问题:显示完整的现存学员信息后,还要显示主菜单

#include <stdio.h> #include <string.h> int menu(); void init(); void listStu(); int insertNewStu(int row); int getStuRowByNo(char no[]); int deleteByNo(); void analyse(char c[]); /***************************************************** students保存学生信息,最多50名 一行代表一个学员信息,每列通过-$-字符串将各项信息分开 stu_num表示已存在的学生数目,假设初始存在2名学员 ******************************************************/ char students[5][200]; int stu_num=2; void main() { int opt; int result=1; init(); while(result){ opt=menu(); if(result==0) { break; } switch(opt) { case 1: //printf("\t执行输入学员信息\n"); result=insertNewStu(stu_num); stu_num=stu_num+1; break; case 2: //printf("\t执行删除学员信息\n"); result=deleteByNo(); stu_num=stu_num-1; break; case 3: printf("\t执行查找学员信息\n"); break; case 4: printf("\t执行修改学员信息\n"); break; case 5: //printf("\t执行输出学员信息数据\n"); listStu(); break; case 0: printf("\t谢谢使用!\n"); result=0; break; default: printf("\t您的输入有误。"); } } } /*打印系统菜单*/ int menu() { int option; printf("\n\t--------------------------------------\n"); printf("\t\t学员信息管理系统\n"); printf("\t--------------------------------------\n"); printf("\t1.输入学员资料\n"); printf("\t2.删除学员资料\n"); printf("\t3.查找学员资料\n"); printf("\t4.修改学员资料\n"); printf("\t5.输出学员信息数据\n"); printf("\t0.退出\n\n"); printf("\t请选择您要进行的操作:"); scanf("%d",&option); return option; } /*初始化2名学员信息*/ void init() { strcpy(students[0],"2010-$-张学友-$-男-$-香港-$-13601234567-$-80-$-60-$-"); strcpy(students[1],"2011-$-王菲-$-女-$-北京-$-13678904567-$-60-$-100-$-"); } /*输出学员所有信息*/ void listStu() { //printf("%s\n",students[0]); //printf("%s\n",students[1]); //printf("%s\n",students[2]); int i; char temp[200]=""; printf("\n\t******现存的学员信息******\n"); printf("学号\t"); printf("姓名\t"); printf("性别\t"); printf("地址\t"); printf("手机\t\t"); printf("Java\t"); printf(".Net\n"); //针对每一行学生信息进行处理 for(i=0;i<stu_num;i++) { strcpy(temp,students[i]); while(strlen(temp)!=0) { analyse(temp); } printf("\n"); } } /*输入学员信息*/ int insertNewStu(int row) { char stu_temp[1][200];//暂存该学员的信息 char n_temp[20]; char a_temp[30]; char c_temp[20]; int i_temp; int flag=0;//用来标识前一项信息是否输入完成 int i; //输入学号 while(flag==0) { printf("\n\t请输入学号:"); scanf("%d",&i_temp); if(i_temp<1000 || i_temp>9999) { printf("\t学号非法,必须4位数字!"); continue; }else { sprintf(c_temp,"%d",i_temp); strcpy(stu_temp[0],c_temp); strcat(stu_temp[0],"-$-"); flag=1; } } //输入姓名 while(flag==1) { printf("\n\t请输入姓名:"); scanf("%s",&n_temp); if(strlen(n_temp)>20) { printf("\t姓名长度过大!"); continue; }else { strcat(stu_temp[0],n_temp); strcat(stu_temp[0],"-$-"); flag=2; } } //输入性别 while(flag==2) { printf("\n\t请输入性别(1男 2女):"); scanf("%d",&i_temp); if(i_temp!=1 && i_temp!=2) { printf("\t性别选择错误!"); continue; }else { if(i_temp==1) { strcat(stu_temp[0],"男"); }else { strcat(stu_temp[0],"女"); } strcat(stu_temp[0],"-$-"); flag=3; } } //输入地址 while(flag==3) { printf("\n\t请输入地址:"); scanf("%s",&a_temp); if(strlen(a_temp)>30) { printf("\t地址长度过大!"); continue; }else { strcat(stu_temp[0],a_temp); strcat(stu_temp[0],"-$-"); flag=4; } } //输入手机号码 while(flag==4) { printf("\n\t请输入手机号码:"); scanf("%s",&c_temp); //判断是否存在非数字等非法字符 for(i=0;i<strlen(c_temp);i++) { if(c_temp[i]<'0' || c_temp[i]>'9') { printf("\t手机号码中包括非数字字符。"); break; } } if(strlen(c_temp)!=11) { printf("\n\t手机号码位数不正确。"); continue; }else { strcat(stu_temp[0],c_temp); strcat(stu_temp[0],"-$-"); flag=5; } } //输入Java的成绩 while(flag==5) { printf("\n\t请输入Java的成绩:"); scanf("%d",&i_temp); if(i_temp<0 || i_temp>100) { printf("\t成绩必须在0-100之间。"); continue; }else { sprintf(c_temp,"%d",i_temp); strcat(stu_temp[0],c_temp); strcat(stu_temp[0],"-$-"); flag=6; } } //输入.Net的成绩 while(flag==6) { printf("\n\t请输入.Net的成绩:"); scanf("%d",&i_temp); if(i_temp<0 || i_temp>100) { printf("\t成绩必须在0-100之间。"); continue; }else { sprintf(c_temp,"%d",i_temp); strcat(stu_temp[0],c_temp); strcat(stu_temp[0],"-$-"); flag=7; } } //确认信息 printf("\n\t*********确认学员信息如下*********\n"); printf("%s",stu_temp); printf("\n\t确认学员信息么(y|n)?"); scanf("%s",&c_temp); if(strcmp(c_temp,"y")==0 || strcmp(c_temp,"Y")==0) { strcpy(students[row],stu_temp[0]); }else { insertNewStu(row); } return flag; } /*指定学员的存储位置,即所在的行位置*/ int getStuRowByNo(char no[]) { int i,j; int pos=-1; char temp[5]=""; for(i=0;i<stu_num;i++) { for(j=0;j<strcspn(students[i],"-$-");j++) { temp[j]=students[i][j]; } if(strcmp(no,temp)==0) { pos=i; break; } } return pos; } /*删除指定学号的学员信息*/ int deleteByNo() { char no[5]; int row; int i,j; printf("\n\t请输入要删除的学员学号:"); scanf("%s",&no); row=getStuRowByNo(no); if(row==-1) { printf("\n\t**********没有该学号的学员信息,请核实**********\n"); return -1; }else { for(i=row;i<50;i++) { for(j=0;j<200;j++) { students[i][j]=students[i+1][j]; } } printf("\n\t********删除成功!********\n"); return 1; } } /*解析学员的信息行*/ void analyse(char c[]) { int i,j; int token; char p_temp[100]=""; token=strcspn(c,"-$-"); //该行第一个分隔符之前的信息项进行解析 for(i=0;i<token;i++) { p_temp[i]=c[i]; } printf("%s\t",p_temp); //去掉已经解析出的信息项,即将后面的信息项依次前移 for(j=0;j<strlen(c)-token;j++) { c[j]=c[token+3+j]; } } 运行后显示主菜单,输入5,显示现存的学员信息,但是成绩显示不出来,成绩如果能显示,还需要显示主菜单。求解决。

c语言中putchar参数为字符数组时,出现中文乱码.VC6.0

c语言中putchar参数为字符数组时,出现中文乱码. #include <stdio.h> int main() { char a; printf("输入一个除a和z之外的小写英文字母\n"); a = getchar(); putchar("\n"); putchar(a); putchar(a + 1); putchar(a - 1); return 0; } ``` ``` ![图片说明](https://img-ask.csdn.net/upload/202003/27/1585308746_392595.jpg) 请问为什么会出现一个中文字符,而且原本的s消失了,为什么r和t未受影响

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

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

删库了,我们一定要跑路吗?

在工作中,我们误删数据或者数据库,我们一定需要跑路吗?我看未必,程序员一定要学会自救,神不知鬼不觉的将数据找回。 在 mysql 数据库中,我们知道 binlog 日志记录了我们对数据库的所有操作,所以 binlog 日志就是我们自救的利器。 接下来就来开启程序员自救之路。 想要自救成功,binlog 这把利器一定要好,在自己之前,我们一定要确定我们有 binlog 这把利器,以下就是确保有 bi...

再不跳槽,应届毕业生拿的都比我多了!

跳槽几乎是每个人职业生涯的一部分,很多HR说“三年两跳”已经是一个跳槽频繁与否的阈值了,可为什么市面上有很多程序员不到一年就跳槽呢?他们不担心影响履历吗? PayScale之前发布的**《员工最短任期公司排行榜》中,两家码农大厂Amazon和Google**,以1年和1.1年的员工任期中位数分列第二、第四名。 PayScale:员工最短任期公司排行榜 意外的是,任期中位数极小的这两家公司,薪资...

我以为我学懂了数据结构,直到看了这个导图才发现,我错了

数据结构与算法思维导图

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

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

华为初面+综合面试(Java技术面)附上面试题

华为面试整体流程大致分为笔试,性格测试,面试,综合面试,回学校等结果。笔试来说,华为的难度较中等,选择题难度和网易腾讯差不多。最后的代码题,相比下来就简单很多,一共3道题目,前2题很容易就AC,题目已经记不太清楚,不过难度确实不大。最后一题最后提交的代码过了75%的样例,一直没有发现剩下的25%可能存在什么坑。 笔试部分太久远,我就不怎么回忆了。直接将面试。 面试 如果说腾讯的面试是挥金如土...

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

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

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是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、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

外包程序员的幸福生活

今天给你们讲述一个外包程序员的幸福生活。男主是Z哥,不是在外包公司上班的那种,是一名自由职业者,接外包项目自己干。接下来讲的都是真人真事。 先给大家介绍一下男主,Z哥,老程序员,是我十多年前的老同事,技术大牛,当过CTO,也创过业。因为我俩都爱好喝酒、踢球,再加上住的距离不算远,所以一直也断断续续的联系着,我对Z哥的状况也有大概了解。 Z哥几年前创业失败,后来他开始干起了外包,利用自己的技术能...

现代的 “Hello, World”,可不仅仅是几行代码而已

作者 |Charles R. Martin译者 | 弯月,责编 | 夕颜头图 |付费下载自视觉中国出品 | CSDN(ID:CSDNnews)新手...

!大部分程序员只会写3年代码

如果世界上都是这种不思进取的软件公司,那别说大部分程序员只会写 3 年代码,恐怕就没有程序员这种职业。

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

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

HTTP与HTTPS的区别

面试官问HTTP与HTTPS的区别,我这样回答让他竖起大拇指!

程序员毕业去大公司好还是小公司好?

虽然大公司并不是人人都能进,但我仍建议还未毕业的同学,尽力地通过校招向大公司挤,但凡挤进去,你这一生会容易很多。 大公司哪里好?没能进大公司怎么办?答案都在这里了,记得帮我点赞哦。 目录: 技术氛围 内部晋升与跳槽 啥也没学会,公司倒闭了? 不同的人脉圈,注定会有不同的结果 没能去大厂怎么办? 一、技术氛围 纵观整个程序员技术领域,哪个在行业有所名气的大牛,不是在大厂? 而且众所...

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

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

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

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

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

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

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

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

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

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

终于懂了TCP和UDP协议区别

终于懂了TCP和UDP协议区别

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

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

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

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

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

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

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

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

计算机编程语言排行榜—TIOBE世界编程语言排行榜(2020年1月份最新版)

深入了解IT/互联网行业及岗位,请参阅通用IT/互联网岗位招聘计划(最新全岗版)。 深入了解职业晋升及学习路线,请参阅最优职业晋升路线和课程学习指南(最新全栈版)。 内容导航: 1、TIOBE排行榜 2、总榜(2020年1月份) 3、本月前三名 4、参考地址 1、TIOBE排行榜 TIOBE排行榜是根据全世界互联网上有经验的程序员、课程和第三方厂商的数量,并使用搜索引擎(如Google

立即提问
相关内容推荐