Time of Update: 2018-12-03
預先處理:編譯之前,由c語言前置處理器對程式碼做的必要的轉換處理。 宏只對程式的文本起作用,它提供了一種對組成c程式的字元進行變換的方法,而不作用於程式中的對象。1. 宏不是函數 #define abs(x) (((x)>=0)?(x):-(x))宏定義中出現的括弧,它們的作用是預防引起與優先順序相關的問題。 即使宏定義中的各個參數與整個結果運算式都被括弧括起來,也仍然還可能有其他問題存在,比如說,一個運算元如果在兩處被用到,就會被求值兩次。 2. 宏不是類型定義
Time of Update: 2018-12-03
1. 連結器 分別編譯(separate
Time of Update: 2018-12-03
符號token:程式中的一個基本資料單元。詞法分析:把程式分解成一個一個符號。 1. 詞法分析中的貪心規則 如果(編譯器)輸入資料流截止某個字元之前都已經被分解為一個個符號,則下一個符號將包括從該輸入符之後可能組成一個符號的最長字串。(K&R) 例: y = x/*p ; /* p指向除數 */ 根據注釋,上述語句似乎是用x除以p所指向的值,把所得商賦給x;而實際上,
Time of Update: 2018-12-03
前面的話:很高興申請到了試讀機會,感謝下華章圖書&w3china。不過呢,只是大學時(很遙遠了,sigh)主要通過錢能的C++程式設計、c++primer還有inside C++ objectmodel學習過C++,大學後沒有太多機會做一些c++的工業應用(用的主要是java)。所以呢,對C++的印象基本上都停留在語言機制層面,呵呵,屬於這本書中作者批評的沒有太多實踐經驗的那群人。希望書評(這也是申請到試讀機會的網友的作業)對考慮入手這本書的tx有點參考。
Time of Update: 2018-12-03
1.
Time of Update: 2018-12-03
最近做的東西,要將vector 中的內容輸出,結果發現有些檔案被交替反覆開啟,所以就想吧vector 中的元素排序,學習中發現下面這篇文章總結的挺好的,分享一下也~C++中當 vector 中的資料類型為基本類型時我們調用std::sort函數很容易實現 vector中資料成員的升序和降序排序,然而當vector中的資料類型為自訂結構體類型時,我們該怎樣實現升序與降序排列呢?有兩種方法,下面的例子能很好的說明:方法1:我們直接來看代碼吧,比較簡單,容易理解:#include "stdafx.h"
Time of Update: 2018-12-03
對於普通類型的對象來說,它們之間的複製是很簡單的,例如:int a=88;int b=a; 而類對象與普通對象不同,類對象內部結構一般較為複雜,存在各種成員變數。下面看一個類對象拷貝的簡單例子。 #include <iostream>using namespace std;class CExample {private: int a;public: CExample(int b) { a=b;} void Show () {
Time of Update: 2018-12-03
**************************************************************
Time of Update: 2018-12-03
**************************************************************************************原文連結:http://main.linuxfocus.org/ChineseGB/March2005/article371.shtml************************************************************************************************
Time of Update: 2018-12-03
這也是給愛問的一個朋友遍的,不知道還有沒有好的方法。 Your Ad Here#include <stdio.h>#include <math.h>#define EX 0.000001int main()...{ double x=0.0, temp=1.0, sin=0.0; int i; printf("Please input a degree:"); scanf("%lf",&x); temp=x; i=0 ; while ( fabs(temp) &
Time of Update: 2018-12-03
**********************************原文連結:http://www.cplusplus.com/doc/tutorial/**********************************動態記憶體直道現在,在我們的所有程式中,我所擁有的所有有效記憶體就是被我們聲明的變數,在來源程式中就已經確定了他們全部的大小,在程式運行之前。但是,如果我們需要一個塊能在運行期才能確定大小的一個可變總的記憶體該怎麼辦呢?例如,在我們需要一些使用者的輸入來決定所需記憶體空間的總量
Time of Update: 2018-12-03
由於能力有限,只能作出這樣的,有興趣的可以一起探討一下qq:1153672901。#include <windows.h>#include <stdio.h>/*------------農曆轉換函式-----------*/char *GetDayOf(SYSTEMTIME pSt){ /*天幹名稱*/const char *cTianGan[] = {"甲","乙","丙","丁","戊","己","庚","辛","壬","癸"};/*地支名稱*/const char
Time of Update: 2018-12-03
********************************************************* 原文:http://www.cplusplus.com/doc/tutorial/ *********************************************************其他資料類型被定義的資料類型(typedef)C++允許我們基於現有的資料類型來定義我們自己的類型。我們可以通過使用關鍵字typedef來實現,它的形式為:typedef
Time of Update: 2018-12-03
剛剛看到c Traps and Pitfalls 看到了 兩個定義和聲明 覺得有必要理解下 只要大概瞭解下,只是文字遊戲而已舉個例子 大家 只要 知道 函式宣告和函數的定義有區別,其他的就一一了斷了 下面作詳細的介紹: 變數的聲明有兩種情況: (1) 一種是需要建立儲存空間的(定義、聲明)。例如:int a在聲明的時候就已經建立了儲存空間。 (2) 另一種是不需要建立儲存空間的(聲明)。例如:extern int
Time of Update: 2018-12-03
#include <iostream>#include <malloc.h>#include <stdio.h>using namespace std;struct stu{ int *a; int *b;};int main(){ //struct stu *s=new stu[10]; //struct stu s=new stu; stu s = (stu*)malloc(sizeof(stu)+2); /
Time of Update: 2018-12-03
new和delete運算子用於動態分配和撤銷記憶體的運算子new用法: 1. 開闢單變數地址空間 1)new int; //開闢一個存放數組的儲存空間,返回一個指向該儲存空間的地址.int *a = new int 即為將一個int類型的地址賦值給整型指標a. 2)int *a = new int(5) 作用同上,但是同時將整數賦值為5 2. 開闢數組空間
Time of Update: 2018-12-03
random函數不是ANSI C標準,不能在gcc,vc等編譯器下編譯通過。但在C語言中int random(num)可以這樣使用,它返回的是0至num-1的一個隨機數。 可改用C++下的rand函數來實現。rand()%n 範圍 0~n-1rand()主要是實現 產生隨機數,其他我們在這裡可以無視他顯然任意 一個數 rand()%n 範圍顯然是 0~n-1;那麼 如何產生 n~m的數呢? 一樣的 我們只要對rand()進行一些 符號操作就行了;n+rand()%(m-n+1);
Time of Update: 2018-12-03
#include <stdio.h>#include <stdlib.h>int main(){ FILE *fp; fp=fopen("E:\\Recent Files\\test.txt","r"); //若這裡是w模式,那麼 下面的代碼沒有進行寫操作,源檔案就會變成空的了 //你輸出也就沒有用了,所以這裡我們要注意 if (!fp) { printf ("can't find the files\n.");
Time of Update: 2018-12-03
給出n行m列的矩陣,“@”代表有石油,“*”代表沒有,如果含有石油的小塊相鄰,那麼屬於同一塊油田。相鄰包括水平、垂直和斜對角,求油田的數量。BFS代碼#include<stdio.h>int m, n;char grid[105][105];int x[8] = {-1, -1, -1, 0, 1, 1, 1, 0};int y[8] = {-1, 0, 1, 1, 1, 0, -1, -1};struct node{ int x, y; }Q[10005];void
Time of Update: 2018-12-03
思路是貪心,方法就是很水的方法。 做法:1.每次派一個機器人從(1,1)開始往右或往下,走到(24,24)為止。2.如果當前格子有垃圾,就清除。3.如果當前所在的格子右邊有垃圾,就往右走。否則,往下走。4.如果走到了最下邊,就一直往右走;如果走到了最右邊,就一直往下走。5.一個機器人走完,檢查還有沒有垃圾。有就再派一個,沒有就停止。Right[i][j]是(i,j)右邊的垃圾數;Down[i][j]是(i,j)下邊的垃圾數;cnt記錄總的垃圾數;res記錄機器人數。Source