scanf()和for循环的两个问题

scanf("(空格)%c",&ch)和scanf("%c",&ch)的区别。
for(;;){if(不符合控制条件)break;}和for(;循环条件;)的区别

c

15个回答

区别一是scanf(" %c",&ch)前面有空格,输入时需要加入空格,而对于scanf("%c",&ch),不需要直接输入先加空格,如果你第一个打的是空格的话那么
ch将会被赋值为空格
第二个 没有区别都是不符合条件跳出循环

scanf()函数接收输入数据时,遇空格结束一个数据的输入

第一个 区别是前面有空格的 输入数据时也要加空格;
第二个 没有区别 当不符合循环条件时跳出for循环

scanf函数调用的一般格式为:
scanf("格式控制字符串",变量1的地址,变量2的地址,……,变量n的地址);
格式字符串中出现的常规字符(包括转义字符),务必原样输入。如:scanf("%d:%d:%d",&h,&m,&s);假设给h输入12,给m输入30,给s输入10,你就必须输,12:30:10回车。
所以当scanf("(空格)%c",&ch)时,如果你想给将'a'赋值给ch,你就必须输入 (空格)a,然后回车,否则只需输入a,然后回车。

第二个问题 for(;;){if(不符合控制条件)break;}和for(;循环条件;)的区别
for语句的一般格式为:
for(表达式1;表达式2;表达式3)
语句;(循环体)
其中表达式1一般为赋值语句,给变量初值;表达式2一般为循环控制条件;表达式3给循环控制变量增量或减量;但是只要满足变量有初值、存在控制条件以确保循环有意义、变量在循环中发生变化一确保存在某个时刻循环截止,表达式1 2 3 都可省略(或者理解为转移到其他位置),但是分号不能省!
(https://img-ask.csdn.net/upload/201804/15/1523770660_534629.jpg)

第一个,当SCANF遇到空格时,就结束数据的输入
第二个,FOR循环的一般形式有:for(i=0;循环条件;i++)
for执行时首先执行表达式1,然后执行表达式2,如果循环成立,在循环结束后,下一个循环前执行表达式3,然后再执行表达式2进行判断 for(;;){if(不符合控制条件)break;}与for(;循环条件;)无区别,均是当判断为不符合条件后跳出循环。

问题1:scanf输入时,双引号里面是什么样的,输入时也要输入,即有空格是要先输入空格
问题2:两种写法没有区别,第一个是把循环条件放在循环体中而已,第二个是常规用法,二者效果是相同的

第一个 区别是scanf(" %c",&ch)前面有空格,当你输入时也要加入空格,而scanf("%c",&ch),直接输入不需要先加空格,如果你第一个打的是空格的话那么
ch将会被赋值为空格
第二个 没有区别都是不符合条件跳出循环

scanf的第一参数是输入的格式控制,你打了空格就要保证输入的字符前有一个空格,不然会出错。scanf("%c", &input),直接读入一个字符。
两个for语句块都是一样的作用,推荐第二种写法,不要乱用break。

scanf第一个是格式控制
第二个 没有区别都是不符合条件跳出循环

scanf的第一参数是格式控制,打了空格的话下面的赋值会出错,要么直接scanf("%c",&input),要么下面给个getchar函数吃掉

共15条数据 1 尾页
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
c语言为什么在循环中使用scanf函数同时给三个数组输入数值时,后两个数组得不到数值

![图片说明](https://img-ask.csdn.net/upload/201711/16/1510826009_957410.jpg) 如图所示,为何在scanf中有三个数组时,i没有增加为什么x[]连得三个数值,y[],z[]得不到数值,而分开写就可以,求大佬明解,是scanf 函数的内部问题吗 ![图片说明](https://img-ask.csdn.net/upload/201711/16/1510826237_807275.png)

C语言如何用for循环构建2*2矩阵

2*2矩阵: 1 2 3 4 很简单的矩阵 不过不用scanf输入 直接用for循环输出 我想的方法是定义一个变量x=1,然后在for循环里面,每一次x++存入数组 代码: ``` #include<stdio.h> int main() { int a[2][2]; int i,j,x=1; for(i=0;i<2;i++) for(j=0;j<2;j++) { a[i][j]=x; x++; } printf("%d\n",a[i][j]); return 0; } ``` 输出结果只有1,实在不解

以下两个C程序嵌套for循环中j=i是怎么遍历二维数组的?

#include <stdio.h> int main() { void change(int * p); int a[5][5], * p, i, j; printf("input matrix:\n"); for(i=0; i<5; i++) for(j=0; j<5; j++) scanf("%d",&a[i][j]); p = &a[0][0]; change(p); printf("Now,matrix:\n"); for(i=0; i<5; i++) { for(j=0; j<5; j++) printf("%d ",a[i][j]); printf("\n"); } return 0; } void change(int * p) { int i, j, temp; int * pmax, * pmin; pmax = p; pmin = p; for(i=0; i<5; i++) for(j=i; j<5; j++) { if(* pmax< *(p+5*i+j)) pmax = p + 5 * i + j; if((* pmin> *(p+5*i+j))) pmin = p + 5 * i + j; } temp = * (p+12); *(p+12) = * pmax; * pmax = temp; temp = * p; * p = * pmin; * pmin = temp; pmin = p + 1; for(i=0; i<5; i++) for(j=0; j<5; j++) if(((p+5*i+j)!=p) && (* pmin > * (p+5*i+j))) pmin = p + 5 * i + j; temp = * pmin; * pmin = * (p+4); * (p+4) = temp; pmin = p + 1; for(i=0; i<5; i++) for(j=0; j<5; j++) if(((p+5*i+j)!=(p+4)) && ((p+5*i+j)!=p) && (* pmin > * (p+5*i+j))) pmin = p + 5 * i + j; temp = * pmin; * pmin = * (p+20); * (p+20) = temp; pmin = p +1; for(i=0; i<5; i++) for(j=0; j<5; j++) if(((p+5*i+j)!=p) && ((p+5*i+j)!=(p+4)) && ((p+5*i+j)!=(p+20)) && (* pmin > * (p+5*i+j))) pmin = p + 5 * i + j; temp = * pmin; * pmin = * (p+24); * (p+24) = temp; } 在change函数一开始的两个嵌套for循环中,为什么设j=i?是怎么遍历这个二维数组的?我自己设j=0,也能得到正确答案! #include <stdio.h> int main() { void move(int * pointer); int a[3][3], * p, i; printf("input matrix:\n"); for(i=0; i<3; i++) scanf("%d %d %d",&a[i][0],&a[i][1],&a[i][2]); p = &a[0][0]; move(p); printf("Now,matrix:\n"); for(i=0; i<3; i++) printf("%d %d %d\n",a[i][0],a[i][1],a[i][2]); return 0; } void move(int * pointer) { int i, j, t; for(i=0; i<3; i++) for(j=i; j<3; j++) { t = * (pointer+3*i+j); * (pointer+3*i+j) = * (pointer+3*j+i); * (pointer+3*j+i) = t; } } 在这个程序的move函数中,如果把嵌套的for循环中的j=i改为j=0,就得不到正确的答案了!

关于c语言中scanf的字符连续输入问题

#include<stdio.h> int main() { int i,j; char n[10][10]; for(i=0;i<4;i++) for(j=0;j<4;j++) { scanf("%c",&n[i][j]); } printf("\n"); for(i=0;i<4;i++) for(j=0;j<4;j++) { printf("%c",n[i][j]); } return 0; } ![图片说明](https://img-ask.csdn.net/upload/201611/25/1480085985_425991.png)

关于for循环的条件——C语言求素数??

小白刚学,不是很明白for循环的条件。 譬如求素数这题,代码如下: #include<stdio.h> int main(){ int i,m,n; int sum=0; int cnt=0; scanf("%d %d",&m,&n); if(m==1){ m=2; } for(i=m;i<=n;i++){ int isPrime=1; int k=1; for(k=2;k<i-1;k++){ if(i%k==0){ isPrime=0; break; } } if(isPrime==1){ cnt++; sum+=i; } } printf("%d %d",cnt,sum); return 0; } --------------------------------------------- 代码的基本意思我本来是理得清的,但是越想越乱,不是很明白 for(k=2;k<i-1;k++),这段什么意思,为什么要让k<i-1,试着debug调试了还是看不明白,烦请各位解答!另:关于for循环里的条件要怎么去判断它到底是小于还是小于等于之类的?有没有什么简单的例子呢?谢谢各位!

第一个for循环结束后第二个for不执行,当把第一个for删掉后,后面的for又会执行

#include<stdio.h> int main(void) { int i,j,n; while(scanf("%d",&n)==1) for(i=1;i<=n/2+1;i++) { for(j=1;j<=n;j++) { if(j==n/2+2-i||j==n/2+i) { printf("*"); } else { printf(" "); } } printf("\n"); } for(i=n/2+2;i<=n;i++) { for(j=1;j<=n;j++) { if(j==i-n/2||j==n+n/2+1-i) { printf("*"); } else { printf(" "); } } printf("\n"); } } ``` ```

GO中的第二个scanf跳转扫描[重复]

<div class="post-text" itemprop="text"> <div class="question-status question-originals-of-duplicate"> <p>This question already has an answer here:</p> <ul> <li> <a href="/questions/17401709/why-doesnt-fmt-scanf-in-go-wait-for-user-input" dir="ltr">Why doesn't fmt.Scanf in Go wait for user input?</a> <span class="question-originals-answer-count"> 1 answer </span> </li> </ul> </div> <p>Dears,</p> <p>I am writing some basic programs that need to receive more than one variable, following the formed</p> <pre><code>fmt.printf ("Report number") fmt.scanf ("%f", &amp;num1) fmt.printf ("Report number") fmt.scanf ("%f", &amp;num2) </code></pre> <p>But the second scanf is always skipped, if I put a third, it is read normally. How do I do it, so that all Scanfs are recognized?</p> </div>

C语言:整型值N在for循环前为输入值,在经过for循环后锁定为4,问各位大佬是何原因?(若改为a[i] = i + 2, 则N变为6,也不知为何)

int main(void) { int N = 0; int a[N]; int flag; int i; while(1) { printf("Please input the scale of array:\n"); flag = scanf("%d", &N); fflush(stdin); **printf("for循环前:N=%d\n", N); for( i = 0; i < N ; i++) a[i] = i ; printf("for循环后:N=%d\n", N);** if(!flag) break; putchar('\n'); } return 0; }

用getchar()和for循环求出输入一串字符大写字母,小写字母,和其他字符的个数。

我是一个大一新生,学C语言不久,求大佬指教。问题还比较多。。。 我的程序是这样的 #include <stdio.h> int main() { int a=0,b=0,d=0; char c=getchar(); for (; getchar() != '\n';) { if (c >= 65 && c <= 90) { a++; } else if (c >= 97 && c <= 122) { b++; } else d++; } printf("大写字母有%d个\n", a); printf("小写字母有%d个\n", b); printf("其他字符有%d个\n", d); return 0; } 但是输出结果都在大写字母上了。![图片说明](https://img-ask.csdn.net/upload/201811/22/1542902375_912893.png) 结果是![图片说明](https://img-ask.csdn.net/upload/201811/23/1542902560_463718.png) 求解释,求正确的代码。。。

C语言scanf函数连续输入问题

![图片说明](https://img-ask.csdn.net/upload/201703/07/1488858681_565360.png)

为什么c语言scanf()函数同时输入字符型和整型数据,输入数据错误?

C语言scanf函数同时输入字符型数据和整型数据,第一个字符输入后再按逗号键该字符就成了汉字,而且之后输入的数据也不对。 #include <stdio.h> int main() { char a, b; int m, n; double x; printf("输入对应的数值 a='a',b='A',m=5,n=10,x=18.51:\n"); scanf("%c,%c,%d,%d,%lf", &a, &b, &m, &n, &x); printf("a=%c,b=%c,m=%d,n=%d,x=%lf\n", a, b, m, n, x); return 0; } C语言初学者,希望大神解答,十分感谢!!!!

一个很简单的c语言循环输入问题。

我的想法是提示用户:请输入,然后用户输入。如此循环三次。 而代码跑出来就是只输入一次,然后直接自己跑完了。不知道哪里出了问题,能帮小弟解答一下吗? ```#include<stdio.h> int main(){ int i, input[3], num; num =3; for(i=0; i<num; i++){ printf("请输入\n"); scanf("&d", &input[i]); } return 0; } ```

关于c语言循环嵌套的问题

完全数是其各因子之和正好等于本身的数,如6=1+2+3,28=1+2+4+7+14,所以6,8都是完全数,请编程找出2-20000内的所有完全数.输入整数n,输出第n个完全平方数。 第一种: ``` #include <stdio.h> void main() { int i,n,s=0,k=0; scanf("%d",&n); for(i=2;i<=20000;i++,s=0) { for(int j=1;j<i;j++) { if(i%j==0) s+=j; if(i==s) k++; } if(k==n) {printf("%d\n",i); break; } } } ``` 第二种: ``` #include <stdio.h> void main() { int i,n,s=0,k=0; scanf("%d",&n); for(i=2;i<=20000;i++,s=0) { for(int j=1;j<i;j++) { if(i%j==0) s+=j; } if(i==s) k++; if(k==n) {printf("%d\n",i); break; } } } ``` 这两个的区别就是if(i==s) k++;第一个中是在内循环,第二个是在外循环。但我觉得这两种应该都可以因为第一个是内循环每循环一次就进行判断i是否等于s,直到最后一次判断是否相等、但是第一种输出不出来结果,,请问为啥

新手一个关于循环的问题

先输入一个数n 来表示需要循环几次 但是如果输入了2 在第二次输入字符串的时候 结果是错误的 代码写的烂 轻喷 ``` #include<stdio.h> #include <stdlib.h> void qiuhe(char a[1000],char b[1000]) { char a1[1000]; char b1[1000]; int A[1000]; int B[1000]; int s1=0; int s2=0; for(int i1=0;a[i1]!='\0';i1++) { a1[i1]=a[i1]; A[i1]=atoi(&a1[i1]); s1+=1; } for(int i2=0;b[i2]!='\0';i2++) { b1[i2]=b[i2]; B[i2]=atoi(&b1[i2]); s2+=1; } int g[1000]; int h[1000]; int j[1000]; int t=0; while(t<1000) { g[t]=0; h[t]=0; j[t]=0; t++; } for (int i3=0;i3<s1;i3++) { g[i3]=A[s1-i3-1]; } for (int i4=0;i4<s2;i4++) { h[i4]=B[s2-i4-1]; } int c=s1>s2?s1:s2; int final[1000]; for(int i=0;i<c;i++) { j[i]+=g[i]+h[i]; if(j[i]>=10) { j[i]-=10; j[i+1]+=1; } final[i]=j[i]; final[i+1]=j[i+1]; } for(int r=c;r>-1;r--){ if(r==c&&final[r]==0) continue; printf("%d",final[r]); } } int main() { char x[1000],y[1000]; int n; scanf("%d",&n); while(n){ scanf("%s%s",x,y); qiuhe(x,y); if(n!=1){printf("\n\n");} else {printf("\n");} n--; } } ```

@数据结构大神,链接两个循环链表,第44行为何不对?求解释~

# include<stdio.h> # include<stdlib.h> typedef struct Node { char data; struct Node *next; }Node,*Linklist;//先定义、后使用 int len; Linklist Createlist(int *array,int len) { Linklist head,temp,ptr; int i; head=(Node*)malloc(sizeof(Node)); if(!head) {printf("内存分配失败!");return NULL;} head->next=NULL; head->data=array[0]; temp=head; for(i=0;i<len;i++) { ptr=(Node*)malloc(sizeof(Node)); if(!ptr) {printf("内存分配失败!");return NULL;} ptr->data=array[i]; temp->next=ptr; temp=temp->next; } ptr->next=head; return head; }//建立循环链表 ,只有head的指针域为空 Linklist Merge(Linklist LA,Linklist LB) { Linklist p=LA,q=LB; p=(Linklist)malloc(sizeof(Node));q=(Linklist)malloc(sizeof(Node)); while(p->next!=LA)p=p->next;while(q->next!=LB)q=q->next;//查找最后链表最后一位。哪里不对? p->next=LB->next;q->next=LA; free(LB); do{ printf("%c,\n",LA->data); LA=LA->next ; }while(LA!=NULL); return(LA);//两个链表连接,形成环 } int main() { int A[100],B[100],lenA,lenB,i; Linklist La,Lb; printf("\ninput lenA lenB:\n");scanf("%d %d",&lenA,&lenB); printf("\ninput A[i]:\n"); for(i=0;i<lenA;i++) scanf("%d",&A[i]); printf("\ninput B[i]:\n"); for(i=0;i<lenB;i++) scanf("%d",&B[i]); La=Createlist(A,lenA);Lb=Createlist(B,lenB); Merge(La,Lb); getch(); //return 0; } ![图片说明](https://img-ask.csdn.net/upload/201511/15/1447577667_447019.png) ![图片说明](https://img-ask.csdn.net/upload/201511/15/1447577681_116122.png)

C语言循环求值问题求解

先上代码 ``` #include <stdio.h> int main(void) { long lLimit; float fSum1 = 0.0,fSum2 = 0.0; printf("请输入一个数值\n"); scanf("%ld",&lLimit); for(int i = 1; i <= lLimit; i ++) fSum1 += (1/i); for(int i = 1; i <= lLimit; i ++) { int a = 1; for(int j = 1;j < i; j++) a *= -1; fSum2 += a*(1/i); } printf("1 + 1/2 + 1/3 +....前%ld项和为 %f\n",lLimit,fSum1); printf("1 - 1/2 + 1/3 - 1/4 + 1/5....前%ld项和为%f \n",lLimit,fSum2); printf("两个数列总和为 %f \n",fSum1+fSum2); return 0; } ``` 程序的目的看最后的两个printf 下面是运行结果 ![图片说明](https://img-ask.csdn.net/upload/201906/20/1561004987_960898.png) 不论我输入什么数字都是这个结果。 求大神指出问题。

for语句的镶嵌是怎么回事?

int n,t,i,j,sum=0; scanf("%d",&n); for(i=1;i<=n;i++) { t=1; for(j=1;j<=i;j++) t=t*j; sum=sum+t; } printf("%d",sum); system("pause");

解决一个计算器跳出循环

代码: #include<stdio.h> #include <stdlib.h> #include<malloc.h> #define N 100 //定义接收字符串大小 typedef struct StackNode { int num_ch; //数字和符号都用int存储 struct StackNode *next; } StackNode; //创建一个链栈 注意我的栈最后一个元素无意义但必须存在 因为方便在表达式末尾进行操作 StackNode *CreatStackNode() { StackNode *q=(StackNode *)malloc(sizeof(StackNode)); if(q==NULL)return NULL; q->num_ch =0; q->next=NULL; return q; } //直接给最后一个元素赋值 并新建一个无意义的结点作为最后元素 int push(StackNode *p,int num) { while(p->next!=NULL) { p=p->next; } p->num_ch=num; StackNode *q=(StackNode *)malloc(sizeof(StackNode)); q->num_ch =0; q->next=NULL; p->next=q; return 0; } // 最后一个无意义的直接free // 倒数第二个next置空,返回倒数第二的值 int Pop(StackNode *p) { int tmp; if(p->next==NULL) return -1;//只有头,无值时无法Pop while(p->next->next!=NULL) { p=p->next; } tmp=p->num_ch; free(p->next); p->num_ch = 0; p->next = NULL; return tmp; }//获取栈顶元素 int GetTop(StackNode *p) { while(p->next->next!=NULL) { p=p->next; } return p->num_ch; } //判栈空 如果只剩一个结点(这是个无意义的) 那么就为空 int Empty(StackNode *p) { if(p->next==NULL) return 1; return 0; } //显示栈的所有元素 void DispStack(StackNode *p) { if(p->next==NULL) return;//只有头,无值时无法Pop while(p->next!=NULL) { printf("%d,",p->num_ch); p=p->next; } putchar(10); } //计算int变量的长度 例如1234长度为4 int sum_int(int in) { int len=0; while(in!=0) { len++; in/=10; } return len; } // 符号优先级判断 返回: 1(opt1>opt2) -1(opt1<opt2) 0(opt1=opt2) 注意符号的ASSIC码:43(+) 45(-) 42(*) 47(/) int opt_max(int opt1,int opt2) { if(42==opt1||47==opt1) { if(43==opt2||45==opt2) { return 1; } return 0; } else { if(42==opt2||47==opt2) { return -1; } return 0; } } //计算a和b在mode符号的运算结果 int cal(int a,int b,int mode) { int re=-1; switch(mode) { case 43: re=a+b; break; case 45: re=a-b; break; case 42: re=a*b; break; case 47: re=a/b; break; default: break; } return re; } //计算表达式的值 int cal(char *str) { int num1,num2,opt1,opt2; StackNode *num,*opt; num=CreatStackNode(); //创建数字栈 opt=CreatStackNode(); //创建符号栈 while(1) { if('\0'==*str) // 读到字符串末尾 { //如果最后一个符号是*或/则会剩下三个数字和两个符号 //如果最后一个符号时+或-则会剩下两个数字和一个符号 //结果只是算两次和算一次的问题 opt1=GetTop(opt); if((42==opt1)||(47==opt1)) { num2=Pop(num); num1=Pop(num); opt2=Pop(opt); push(num,cal(num1, num2, opt2)); } num2=Pop(num); num1=Pop(num); opt2=Pop(opt); num1=cal(num1, num2, opt2); break; } else if('('==*str) // 读到(,注意进栈的时(的ASSIC码40 { push(opt,(int)'('); str++; } else if(')'==*str) // 只是判断)不进入栈 { while(1) // 本循环会计算与)匹配的最近的(地方为之 { if(40==GetTop(opt)) // 如果当前栈顶是(则弾栈退出 { Pop(opt); break; } else // 否则弾两个数字,一个符号进行运算 { // 结果入操作数栈 num2=Pop(num); num1=Pop(num); opt2=Pop(opt); push(num,cal(num1, num2, opt2)); } } str++; } else if(('9'>=*str)&&('0'<=*str)) // 如果取到数字则将数字进入栈 { sscanf(str,"%d",&num1); push(num,num1); //将指针移动到当前数字到后面 str=str+sum_int(num1); } else // 取到一个符号 { opt1=(int)*str++; while(1) { if( (1==Empty(opt))||(40 == GetTop(opt)) ) // 如果栈不空则遇到(则进入取到的符号 { // 为空时也要进栈 push(opt,opt1); break; } else { //取出符号栈顶元素 opt2=GetTop(opt); if(0<opt_max(opt1,opt2)) // 当前获取的符号优先级大于栈顶符号 { // 则进栈 push(opt,opt1); break; } else // 栈顶优先级高或者平级则 { // 取两个数和栈顶符号进行运算 num2=Pop(num); num1=Pop(num); opt2=Pop(opt); push(num,cal(num1,num2,opt2)); } } } } } free(num); free(opt); return num1; } int main() { int flag=1; char buf[N]={0}; printf("\t\t********************************$\n"); printf("\t\t* 欢迎您使用本计算器 *\n"); printf("\t\t********************************$\n"); printf(" 作者:张治政\n"); printf("请输入一个运算式(eg:8+6*(9-3)+8/4注意括号为英文式的!):\n"); printf("当你想结束的时候输入一个纯数字就结束了!\n"); while(flag==1) { scanf("%s",buf); if(getchar()=="0000") { flag=0; } printf("%s=%d\n",buf,cal(buf)); } return 0; }

求高手啊 两个有序指针按大小合并到一个指针中,为什么会在第一个while循环中陷入死循环

#include<stdio.h> #include<malloc.h> struct stu { int num; struct stu *next; }; struct stu* creat(void)//建立一个链表 { int n; struct stu *p1,*p2,*head; scanf("%d",&n); p1=head=(struct stu *)malloc(sizeof(struct stu)); p1->next=NULL; for(int i=0;i<n;i++) { p2=(struct stu *)malloc(sizeof(struct stu)); p2->next=NULL; scanf("%d",&p2->num); p1->next=p2; p1=p2; } p1->next=NULL; return head; } int main() { struct stu *p1,*pt_a,*pt_b; struct stu* head=(struct stu *)malloc(sizeof(struct stu));新链表的表头 p1=head; p1->next==NULL; pt_a=creat(); pt_b=creat(); while(pt_a->next&&pt_b->next)//判断一个链表是否遍历到结尾 { if(pt_a->next->num>pt_b->next->num);判断大小 { p1->next=pt_b->next;连接到新链表上 p1=pt_b->next;新表指针指向最后一个 pt_b=pt_b->next;原先的链表后移 } 经过调试发现旧链表不会后移,所以一直死循环 else{ p1->next=pt_a->next; p1=pt_a->next; pt_a=pt_a->next; } } p1->next=NULL; while(head->next!=NULL) { printf("%5d",head->next->num); head=head->next; } return 0; }

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

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

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

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

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

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

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

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

和黑客斗争的 6 天!

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

点沙成金:英特尔芯片制造全过程揭密

“亚马逊丛林里的蝴蝶扇动几下翅膀就可能引起两周后美国德州的一次飓风……” 这句人人皆知的话最初用来描述非线性系统中微小参数的变化所引起的系统极大变化。 而在更长的时间尺度内,我们所生活的这个世界就是这样一个异常复杂的非线性系统…… 水泥、穹顶、透视——关于时间与技艺的蝴蝶效应 公元前3000年,古埃及人将尼罗河中挖出的泥浆与纳特龙盐湖中的矿物盐混合,再掺入煅烧石灰石制成的石灰,由此得来了人...

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

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、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

我说我不会算法,阿里把我挂了。

不说了,字节跳动也反手把我挂了。

优雅的替换if-else语句

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

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

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

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

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

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

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

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

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

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

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

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

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

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

你打算用Java 8一辈子都不打算升级到Java 14,真香

我们程序员应该抱着尝鲜、猎奇的心态,否则就容易固步自封,技术停滞不前。

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

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

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

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

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

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

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

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

《经典算法案例》01-08:如何使用质数设计扫雷(Minesweeper)游戏

我们都玩过Windows操作系统中的经典游戏扫雷(Minesweeper),如果把质数当作一颗雷,那么,表格中红色的数字哪些是雷(质数)?您能找出多少个呢?文中用列表的方式罗列了10000以内的自然数、质数(素数),6的倍数等,方便大家观察质数的分布规律及特性,以便对算法求解有指导意义。另外,判断质数是初学算法,理解算法重要性的一个非常好的案例。

《Oracle Java SE编程自学与面试指南》最佳学习路线图(2020最新版)

正确选择比瞎努力更重要!

一文带你入门Java Stream流,太强了

两个星期以前,就有读者强烈要求我写一篇 Java Stream 流的文章,我说市面上不是已经有很多了吗,结果你猜他怎么说:“就想看你写的啊!”你看你看,多么苍白的喜欢啊。那就“勉为其难”写一篇吧,嘻嘻。 单从“Stream”这个单词上来看,它似乎和 java.io 包下的 InputStream 和 OutputStream 有些关系。实际上呢,没毛关系。Java 8 新增的 Stream 是为...

立即提问
相关内容推荐