学习基础和C语言基础调查
一、一种比大多数人(超过90%以上)更好的技能
说句实话,我还没有那种特别特别自信的、说我能拿得出手的、所谓能超过百分之九十以上的人的技能。毕竟人外有人,天外有天。
姑且算上象棋吧,能下的过一些人,碰上一些每天都在下的那种老爷爷可能还是不太招架得过来。
至于说我所积累的经验,总结一下,大量的实战经验和灵活的思维模式。
首先说这头一点吧,实战经验就是大量的练习。有的人下棋就喜欢背棋谱,不过我觉得纸上得来终觉浅,或者说,我觉得真刀真枪地干上一局比背棋谱进步得快。其实......我小时候也没想这么多,这都是我现在瞎bb的。我的象棋算是野路子学来的,小时候和爷爷奶奶下,一点点启蒙的技巧还是会的。再后来,上小学了,和班里同学下,参加比赛等等。从始至终没有上过正儿八经的培训班之类的,所以,到底应该怎么学我也不知道。
但是我觉得下的多,还是有帮助的。见的套路多,中的招多了,自然能长记性。
所以我现在把这个经验总结为:大量的实战经验。小时候打下的底子,纵观全局,不可或缺。
第二,死脑筋还是不行的,思维要灵活。对局时动脑子想想几步之后走到哪里了,有没有便宜可占,猜对手想干什么,其中有没有杀机;对局后动脑子,这个对手棋路风格如何,刚才有没有失误,等等。如果不动脑子,那么进步就是一种奢望。
勤能补拙,静能生慧。我觉得这是与老师博客中的学习经验的最大共通之处,也是所有求学道路上的秘诀。
二、有关C语言学习的调查
你是怎么学习c语言的?与你的高超技能相比,C语言的学习有什么经验和教训?
刚刚开始的时候,基础的知识了解一点,一些基本的语句。
然后就是刷题刷题刷题......老师给的那个c语言在线题库。
之后慢慢开始学会看错误信息,找错,学会用debug等等,再后来帮同学改程序,一些易错的地方越来越熟练,到最后慢慢地开始和大佬们交流,看看其他人是怎么写的。
总而言之就是不断进步嘛,自己发现问题解决问题,查书,问同学,问度娘,问老师。这就是我的,最大的收获。
目前为止估算自己写过多少行C代码?理解的情况如何?量变引起质变,如何平衡质和量?
(老师对不起写了多少行C语言代码我是真的心里没数啊)
等等啊,我们现在一个实验写程序大概100~200行,这样算下来,我们做了这么多大大小小的实验,应该有个小几千行了。
目前写的代码都还是能理解的,毕竟都是自己写的,应该不存在看不懂的问题;其他人的代码也还是看得懂,只是要多看两眼,多琢磨琢磨,可能是代码看少了,不太熟练吧。
量变引起质变,这是必然的规律。我觉得我们只要慢慢积累,自然集腋成裘,没有必要刻意追求质变的发生。也许有一天,我们回过头来,看见自己从最开始的“Hello world!”到后来能自己编个小应用,我们就会感叹不知不觉中质变的发生。
学过了C语言,你分的清数组指针,指针数组;函数指针,指针函数这些概念吗?
也不知道我记的是不是对的。
数组指针,说白了是指针嘛,指向一个数组的指针;指针数组是一个数组,数组里储存的是指针。
函数指针类似,函数指针是指向一个函数的指针;指针函数是一个函数,函数返回值是一个指针。
学过了C语言,你明白文件和流的区别和联系吗?如何区分文本文件和二进制文件?如何编程操作这两种文件?
第一个问题只知道一点点......
文件指的是电脑储存设备上的数据信息,流简单的说应该是字节序列,文件的输入输出控制,外部输入输出设备等等。关系:流是一种向文件写入字节和从文件读取字节的方式。
第二个问题......我觉得广义上讲,文本文件本质就是二进制文件的......所以二者的区别并不是物理上的,而是逻辑上的。二进制文件可以存储char/int/short/long/float/……各种变量值。作为特殊的二进制文件,文本文件只能存储char型字符变量。因此,文本文件每条数据通常是固定长度的,而二进制文件不是。
文本文件编辑器就可以读写,比如记事本;二进制文件需要特别的解码器。
学过了C语言,你知道什么叫面向过程程序设计吗?它解决问题的方法是什么?
C语言是面向过程的程序设计。所谓过程就是,酒一口一口喝,步子一步一步走,先干嘛再干嘛,顺序很重要,对于计算机而言只需要一个一个地实现就行了。
解决问题的办法就是把一个程序模块化,从上往下步步求精即可。
在C语言里面,什么是模块?你写过多个源文件的程序吗?
在设计一个较大的程序时,可以把它分成若干个程序模块,每一个模块包括一个或多个函数,每一个函数实现一个特定的功能。C语言通过函数来实现其模块化功能的。
多个源程序倒没有写过,目前只写一个源程序的。
学过了C语言,你知道什么是“高内聚,低耦合”吗?这个原则如何应用到高质量程序设计中?
“高内聚,低耦合”其实按字面意思也很好懂,程序的模块与模块之间的耦合度要低,接口处尽量简单;模块内部要做得精细,模块内的函数功能联系要紧密。
应用上主要的问题在于模块的划分。一方面要考虑耦合性:为了提高模块的独立性,模块与模块之间的联系应该尽可能的减少,尽量在主函数里调用,实现非直接耦合;另一方面要考虑内聚:尽可能实现一个模块对应一个功能。
学过了C语言,你如何把数组A的内容复制到数组B中?如何查找整数数组A中有没有数字5?如何对整数数组A进行排序(从小到大,从大到小)?写出相应的程序。
(假设数组char型,长度为5,数组a是1,2,a,b,c)
把数组A的内容复制到数组B中:最简单就是脚标循环,一个一个对应着写。
#include <stdio.h>
#include <stdlib.h>
int main()
{
char a[5]={‘1‘,‘2‘,‘a‘,‘b‘,‘c‘};
char b[5];
int i;
for (i=0;i<5;i++)
{
b[i] = a[i];
}
return 0;
}
如何查找整数数组A中有没有数字5?脚标循环查找。
#include <stdio.h>
#include <stdlib.h>
int main()
{
char a[5]={‘1‘,‘2‘,‘a‘,‘b‘,‘c‘};
int i;
int flag = 0;
for (i=0;i<5;i++)
{
if (a[i]==‘5‘)
{
flag = 1;
break;
}
}
if (flag)
printf("Bingo!");
else
printf("Not Found!");
return 0;
}
如何对整数数组A进行排序(从小到大,从大到小)?冒泡排序。
下面是从大到小排序(按照ASCII码排序)。从小到大只需要将判断条件,由“if (a[j]<a[j+1])”
改为“if (a[j]>a[j+1])”
。
#include <stdio.h>
#include <stdlib.h>
int main()
{
char a[5]={‘2‘,‘1‘,‘b‘,‘a‘,‘c‘};
int i,j;
int temp;
for (i=0;i<4;i++)
{
for (j=0;j<4-i;j++)
{
if (a[j]<a[j+1])
{
temp = a[j];
a[j] = a[j+1];
a[j+1] = temp;
}
}
}
for (i=0;i<5;i++)
{
printf("%c",a[i]);
}
return 0;
}
写一个程序,统计自己C语言共写了多少行代码?
这个是大二上做中国剩余定理实验的代码,前前后后敲了一周吧。
//中国剩余定理实验
#include <stdio.h>
#include <stdlib.h>
#define N 10000
#define M 10
struct equa //方程:bx = a mod n;
{
int a;
int b;
int n;
};
int modni(int a,int b);
//模逆运算 m = a^(-1) mod b
int gcd(int a,int b);
//求最大公因子
int gcd(int a,int b)//辗转相除法求最大公因子
{
int temp;
if (a<b)
{
temp = a;
a = b;
b = temp;
}
while (b!=0)
{
temp = a % b;
a = b;
b = temp;
}
return a;
}
int modni(int a,int b)//模逆运算 m = a^(-1) mod b
{
int v1=0,v2=1,q,temp;
if (a>b)
{
a = a % b;
}
while (a!=0)
{
q = b/a;
v1 = v1-v2*q;
temp = b % a;
b = a;
a = temp;
temp = v1;
v1 = v2;
v2 = temp;
}
return v1;
}
int main()
{
int x,xn; //方程总个数
struct equa E[M],B[M]; //两个方程组,互写(bx = a mod n)
int m0 = 1; //m0 是中国剩余定理的 m
int m[M]; //m 是中国剩余定理的 M
int mm[M]; //mm 是中国剩余定理的 M‘
int shit = 0; //最终结果 x = shit mod m0
int i = 0,j,k; //角标
int g1,g2; //互素分解的临时储存位置
printf("Please input the number of equations:\n");
scanf("%d",&x);
xn = x; //数据保留
if (x>M)
{
printf("Error!\nx>%d\n",M);
exit(0);
}
while (x--)
{
printf("Please enter b,a,n:\n(bx = a mod n)\n");
if (scanf("%d",&E[i].b)&&scanf("%d",&E[i].a)&&scanf("%d",&E[i++].n))
continue;
else
{
printf("\nError!");
exit(0);
}
}
for (i = 0;i<xn;i++) //计算m
m0 *= E[i].n;
for (i = 0;i<xn;i++) //计算M
m[i] = m0/E[i].n;
for (i = 0;i<xn;i++) //计算M‘
mm[i] = modni(m[i],E[i].n);
for (i = 0;i<xn;i++)
shit += m[i]*mm[i]*E[i].a;
shit = shit % m0;
printf("x = %d mod %d",shit,m0);
//程序测试部分
/*for (i = 0;i<xn;i++)
{
printf("%dx = %d (mod %d)\n",E[i].b,E[i].a,E[i].n);
}*/
}
原来的那个程序太长了,我就改了一下,现在这段代码只能解很简单的那种方程了。这个程序掐头去尾共有91行代码。
你知道什么是断点吗?给出自己调试程序的例子。
断点就是程序运行时会自动停止的地方,准确来说应该是在调试过程中,程序运行到断点位置会停止。
程序调试如图所示。
程序运行结果如图所示。
三、参考怎样快速阅读一本书,快速阅读一下云班课中有PPT,每章提出一个问题
第1章
Java的动态特征不太理解。
第2章
为啥有一个“boolean 关闭 = false”?
第3章
3.1.5的例子看不怎么懂......
第4章
不理解“Java支持中文类名、方法名、属性名,并且不会因为乱码问题导致运行期链接失败。这是Java内核支持UTF-8这一特性决定的。”
第5章
所有的类都有自己的子类吗?
第6章
不理解接口和abstract类的具体区别。
第7章
异常类不理解。
第八章往后我基本一脸蒙逼了......后面的边学边问吧,我感觉这学期Java的学习会让我收获不少。
四、关于Java学习
计算机语言的学习我觉得是代码堆出来的。语言的学习离不开环境,而对于计算机语言,代码就是环境。想要提高程序设计能力和培养计算思维,软磨硬泡地训练是必不可少的。“做中学”要求我们有灵活的思维,摆脱“舒适区”,进入“学习区”。