C語(yǔ)言從txt文件中逐行讀入數(shù)據(jù)存到數(shù)組中的實(shí)現(xiàn)方法
首先,要知道數(shù)據(jù)的存儲(chǔ)格式是怎樣的,
65 2 722 542 691 514 644 506 588 524 565 558 608 580 648 586 696 572 482 564
第一行表示數(shù)字的個(gè)數(shù)和維數(shù),所以要先讀入這些信息:
<span style="white-space:pre"> </span>FILE *fp = fopen("2D_Jesscia_keypos.txt", "r"); if ( !fp ) { fprintf( stderr, "! Error: faild to open keypos file \n" ); return -1; } fscanf(fp, "%d %d%c", &in.numberofpoints, &dim, &ne);
這樣就得到了個(gè)數(shù)信息,這樣方便動(dòng)態(tài)的分配內(nèi)存,接下來(lái)就可以逐行讀入數(shù)據(jù)了:
<span style="white-space:pre"> </span>in.pointlist = (REAL *) malloc( in.numberofpoints * 2 * sizeof(REAL) ); char buf[1024]; char pt1, pt2; for (i = 0; i < in.numberofpoints; i++) { if (!feof(fp)) { if (fgets(buf, 1024, fp) == NULL) break; sscanf(buf, "%s %s\n", &pt1, &pt2); in.pointlist[2 * i] = atoi(&pt1); in.pointlist[2 * i + 1] = atoi(&pt2); } }
注意,是現(xiàn)將每一行讀入buf中,這是字符串類型的,然后再利用sscanf將里面的內(nèi)容讀給pt1和pt2,再利用atoi函數(shù)得到數(shù)據(jù)類型的值。
以上就是小編為大家?guī)?lái)的C語(yǔ)言從txt文件中逐行讀入數(shù)據(jù)存到數(shù)組中的實(shí)現(xiàn)方法全部?jī)?nèi)容了,希望大家多多支持腳本之家~
相關(guān)文章
詳解C++ STL vector容器訪問(wèn)元素的幾種方式
這篇文章主要介紹了詳解C++ STL vector容器訪問(wèn)元素的幾種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05C++ STL_vector 迭代器失效問(wèn)題的解決方法
迭代器的主要作用就是讓算法能夠不用關(guān)心底層數(shù)據(jù)結(jié)構(gòu),其底層實(shí)際就是一個(gè)指針,或者是對(duì)指針進(jìn)行了封裝,迭代器失效,實(shí)際就是迭代器底層對(duì)應(yīng)指針?biāo)赶虻目臻g被銷毀了,對(duì)迭代器失效我們了解了,那么現(xiàn)在我們就分析,在vector中哪些操作會(huì)導(dǎo)致迭代器失效2023-08-08解析C++編程中virtual聲明的虛函數(shù)以及單個(gè)繼承
這篇文章主要介紹了C++編程中virtual聲明的虛函數(shù)以及單個(gè)繼承,剖析虛函數(shù)和單個(gè)基類所能夠繼承的成員,要的朋友可以參考下2016-01-01C/C++實(shí)現(xiàn)貪吃蛇逐步運(yùn)動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了C/C++實(shí)現(xiàn)貪吃蛇逐步運(yùn)動(dòng)效果的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-05-05