C/C++程序集

#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>

int main()
{
        int s, afd;
        int len;
        struct sockaddr_in sin, csin;
        char buf[32] = "";

        memset(&sin, 0, sizeof(sin));

        sin.sin_family = AF_INET;
        sin.sin_port = htons(5678);
        sin.sin_addr.s_addr = INADDR_ANY;
        //sin.sin_addr.s_addr = INADDR_ANY;

        s = socket(PF_INET, SOCK_STREAM, 0);
        if (bind(s, (struct sockaddr *)&sin, sizeof(sin)) < 0) {
                printf("bind error\n");
        }
        if (listen(s, 32) < 0 )
                printf("listen error\n");

        while (1) {
                afd = accept(s, (struct sockaddr *)&csin, &len);
                if (afd < 0) {
                        printf("accept error\n");
                        continue;
                }
                if (read(afd, buf, sizeof(buf)) > 0)
                        printf("%s\n", buf);
                close(afd);
        }
}

执行‘telnet localhsot 5678’测试。 
tcp 一对一
udp 一对多 多对一 多对多
质数验证程序:

-bash-3.2$ more prime.c
#include <stdio.h>
#include <time.h>
#include <math.h>
#include <string.h>
#include <stdlib.h>
 
#define  E9        1072000000 
#define  E10       10000000000
#define  E11       100000000000
#define  E12       1000000000000
 
char table[E9];
 
int num = 0;
//int prime[E8];
 
void cal_table()
{
        int j, k;
        time_t t1, t2;
 
        t1 = time(NULL);
 
        memset(table, 1, E9);
        for (j = 2 ; j < E9; j++) {
                if ( table[j] ) {
                        num++;
                        for ( k = j + j; k < E9; k += j )
                        {
                                table[k] = 0;
                        }
                }
        }
        t2 = time(NULL);
 
        printf("Totaly %d primes until E9, cost %d time_t.\n", num, t2 - t1);
}
int main()
{
    int i;
    cal_table(); 
    return 0;
}
 
-bash-3.2$ gcc prime.c
-bash-3.2$ ./a.out
Totaly 54316419 primes until E9, cost 179 time_t.
-bash-3.2$
Little endian把低字节存放在内存的低位;而Big endian将低字节存放在内存的高位;Intel的CPU是little endian,Sun Sparc的CPU是big endian。

假设从地址0x00000000开始的一个字(WORD)中存有数据0x1234abcd。

Little endian机器,从低到高内存的存放顺序是:0x00000000-0xcd,0x00000001-0xab,0x00000002-0x34,0x00000003-0x12 

Big endian机器,从低到高内存的存放顺序是:0x00000000-0x12,0x00000001-0x34,0x00000002-0xab,0x00000003-0xcd 

#include <stdio.h> 
int main() 
{ 
    int a = 0x12345678; 
    char *p = (char * )&a; 
    printf("%x %x %x %x\n", *p, *(p+1), *(p+2), *(p+3)); 
    return 0; 
} 

-bash-3.2$ ./a.out 
78 56 34 12 
-bash-3.2$ uname -a 
Linux fedora.unix-center.net 2.6.27.10-grsec2.1.12 #2 SMP Fri May 8 07:04:03 CST 2009 i686 i686 i386 GNU/Linux 

-bash-3.00$ ./a.out 
12 34 56 78 
-bash-3.00$ uname -a 
SunOS t1000 5.10 Generic_118833-33 sun4v sparc SUNW,Sun-Fire-T1000 Solaris 

以下程序在Linux上用GCC编译运行,结果是0.000000,其实这种代码编译器应该报错,最起码是警告,可是.......

#include <stdio.h>
double sum(); 
int main() { 
     int x = 10; 
     int y = 10; 
     double z = sum(x,y); 
     printf("%lf\n", z); 
     return 0; 
} 
double sum(double x, double y) { 
     return (x+y); 
}
反向排列字符串

#include <stdio.h> 
#include <string.h> 
#include <stdlib.h>  

char a[128] = "I am fine thank you asdasd aaaaaa bbbbbb cccccc cccccccccccc"; 

void reserve (char * in, char *out) 
{ 
     char *p = in + strlen(in) - 1; 
     while (1) { 
         while (1) { 
             if (*p == ' ' || p == in) 
                 break; 
             p--; 
         } 
        if (p == in) { 
            strcat(out, p); 
            return; 
        } 
        strcat(out, p+1); 
        strcat(out, " "); 
        while (*(p - 1) == ' ') 
            p--; 
        *p = '\0'; 
    } 
} 

int main() 
{ 
    char *b; 
    b = malloc(128); 
    reserve(a, b); 
    printf("%s\n", b); 
    free(b); 
    return 0; 
} 
打印1-20的全排列。 

#include<stdio.h> 
void print_it(int n, int arr[]); 
void arrange_all(int size, int arr[], int pos); 
int main() 
{ 
    int a[20] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20}; 
    arrange_all(20, a, 0); 
    return 0; 
} 
void arrange_all(int size, int arr[], int pos) 
{ 
    int i, tmp; 
    if (pos + 1== size)  { 
        print_it(size, arr); 
        return; 
    } 
    for (i = pos; i < size; i++)  { 
        tmp = arr[pos]; 
        arr[pos] = arr[i]; 
        arr[i] = tmp; 
        arrange_all(size, arr, pos + 1); 
        tmp = arr[pos]; 
        arr[pos] = arr[i]; 
        arr[i] = tmp; 
    } 
} 
void print_it(int n, int arr[]) 
{ 
    int i; 
    static int cnt = 0; 
    printf("%21d: ", ++cnt); 
    for (i = 0; i < n; i++) 
         printf("%4d ", arr[i]); 
    printf(""); 
} 
#include <stdio.h> 

int func(int n) 
{ 
    int a[30]; 
    int i, j, t; 
    int count=0; 

    for(i=0;i<n;i++) a[i]=i+1; 
    for(;;) { 
        printf("%4d: ", ++count); 
        for(i=0;i<n;i++) printf("%d ", a[i]); 
        printf("\n"); 
        for(i=n-2;i>=0;i--) if(a[i]<a[i+1]) break; 
        if(i<0) break; 
        for(j=n-1;;j--) if(a[j]>a[i]) break; 
        t=a[j], a[j]=a[i], a[i]=t; 
        i++, j=n-1; 
       while(i<j) { 
            t=a[j], a[j]=a[i], a[i]=t; 
            i++, j--; 
        } 
    } 
    return(0); 
} 

main() 
{ 
    func(20); 
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容