您好,登錄后才能下訂單哦!
文化、時(shí)代、生活 仿佛還在昨天。
C語言嚴(yán)謹(jǐn)?shù)膩碚f是一門面向過程的語言,面向?qū)ο?、面向過程到底是怎樣,困擾了我一年兩年的時(shí)光。C的好處靈活性、效率高這些就不一一介紹來了,C++與C其實(shí)并不是一門語言,C++兼容C,C++面向?qū)ο?。就像起床,C就會定義怎樣睜眼,怎樣動胳膊等等,而C++簡答說把這些過程存儲了,函數(shù)調(diào)用,換句話說C++的標(biāo)準(zhǔn)庫要比C強(qiáng)大多的。
既然都這樣了還學(xué)啥C語言,直接學(xué)C++不就好了嗎?這也完全沒問題,直接學(xué)習(xí)C++也是沒有問題的,就像說的那樣這是兩種語言,只不過關(guān)聯(lián)程度大,但是大多數(shù)人還是會從C學(xué)起來,因?yàn)榭梢粤私饷恳粋€(gè)過程,靈活性算是語言中很強(qiáng)的,可以隨心所欲寫自己想要的過程,對于優(yōu)秀的程序員對封裝下面都是很清楚,出現(xiàn)的問題調(diào)試都是在這個(gè)層面完成的,所以C基礎(chǔ)牢固的人與沒接觸過C的人一起學(xué)習(xí)C++考慮的層面,涉及到的程度是不一樣的,久而久之差距會越來越大。
說了那么多廢話就是想說,學(xué)習(xí)C++可以沒C的基礎(chǔ)一樣學(xué)習(xí),C語言可以學(xué),也可以不學(xué),但是學(xué)好了之后你會在編程上看到更多深層面知識。
學(xué)習(xí)C之后,從基礎(chǔ)學(xué)習(xí)到函數(shù)卻不知道記錄什么樣的重點(diǎn)與大家分享交流,留下的是一堆文本代碼,學(xué)習(xí)C這段時(shí)間最大的感觸認(rèn)真兩個(gè)字的確不簡單,最近也逛一些論壇一起來看幾個(gè)有意思的小故事
1、關(guān)于scanf
scanf("%f %f",&a,&b);scanf是接收用戶數(shù)據(jù)的關(guān)鍵字類似于python中raw_input函數(shù),讀取不檢查邊界的!會出現(xiàn)內(nèi)存訪問越界。而且不需要引入stdio.h(inputout)頭文件也可以使用與Printf函數(shù)是一樣的。
scanf接收格式很嚴(yán)格要求,如果中間空格,在命令行輸入時(shí)候必須也是空格,是逗號就得輸入逗號。這個(gè)地方本人就經(jīng)常犯低級的錯(cuò)誤。
普及一下%d(整型1,2,3),%f(浮點(diǎn)型1.0,2.0,3.0),%c(字符串),%f最為有意思,也是比較靈活的double與float類型都用%f接收
sizeof()這個(gè)函數(shù)用來查看這些類型占幾個(gè)bit位,1byte=8bit 一個(gè)字節(jié)8位,**注意并不是int就一定是占4和字節(jié)32位,這是不科學(xué)的,有的書上是2個(gè)字節(jié),有的是4個(gè)字節(jié),其實(shí)占幾個(gè)字節(jié)根據(jù)根據(jù)系統(tǒng)來的**,并不是C定義好的。
再來說兩個(gè)函數(shù)pow這個(gè)函數(shù)在后面全被Double類型取代了,輸入輸出都是double,求立方的函數(shù),自己寫的源碼貼出來供大家參考,本人代碼風(fēng)格是譚老師風(fēng)格,因?yàn)閷W(xué)的他的書,所以有時(shí)候代碼不符合大家感覺
include <stdio.h>
void main()
{
double power(double a,double b);
double x,y;
scanf("%lf,%lf",&x,&y);
printf("%lf\n",power(x,y));
}
double power(double a,double b)
{
double f=1;
int i;
// printf("%f,%f",a,b);
for(i=0;i<b;i++)
{
f*=a;
}
return f;
}
僅供大家參考,那么再來個(gè)有意思的二分法與冒泡排序,其實(shí)本人挺喜歡數(shù)據(jù)姐與算法,因?yàn)楹猛娑覍?shí)用,畢竟是程序的靈魂如下
本人只會有序的冒泡排序,下面是自己初始化一個(gè)數(shù)組,下面是排序+循環(huán)
#include <stdio.h>
void main()
{
int i,j,l,d;
static int a[5]={5,1,3,6,2};
int b[5];
for(i=0;i<5;i++)
{
for(j=i;j<4;j++)
{
if(a[i] > a[j+1])
{
b[j] = a[j+1];
a[j+1] = a[i];
a[i] = b[j];
}
}
printf("{%d}",a[i]);
}
printf("\nPlease enter find numbers:\n");
scanf("%d",&d);
for(l=0;l<5;l++)
{
if(d == a[l])
{
printf("您查詢%d是本數(shù)組中的元素,排在數(shù)組中第%d位",d,l+1);
}
}
printf("\n");
}
下面再來個(gè)二分法查找
#define M 7
#include <stdio.h>
void main()
{
static int a[M]={-12,0,6,16,23,56,80};
int n,start,middle,finlly,found;
start = 0;
finlly = M - 1;
found = 0;
printf("請輸入:\n");
scanf("%d",&n);
while(start <= finlly)
{
middle = (start+finlly)/2;
if(n == a[middle])
{
found=1; break;
}
else if(n > a[middle])
start = middle+1;
else
finlly = middle -1;
}
if(found==1)
printf("您查找%d",middle+1);
else
printf("沒有查找到%d",n);
}
文本粘貼上來的 格式有點(diǎn)不好看,講解就么意思不會的可以討論 畢竟思路是一樣的 百度也有大量學(xué)習(xí)代碼
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。