青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

天之道

享受編程的樂趣。
posts - 118, comments - 7, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

編寫一個返回循環鏈表中節點數的函數

實現代碼如下:

#include<stdio.h>
#include<stdlib.h>
typedef struct node *link;
struct node{ int item; link next; };

int node_number(link p,int n)
{
    int count=0,i;
    for(i=0;i<n-1;i++)
    {
        p=p->next;
    }
    while(p->item)
    {
        p->item=0;
        p=p->next;
        count++;
    }
    return count;
}

int main()
{
    
    int i,N;
    link t=(link)malloc(sizeof(node));
    t->item=1;
    t->next=t;
    link x=t;
    for(i=2;i<=10;i++)
    {
        x = (x->next= (link)malloc(sizeof(node)));
        x->item=i;
        x->next=t;
    }
    printf("Please input the order of node: ");
    scanf("%d",&N);
    printf("total number of nodes is: %d\n",node_number(t,N));
    return 0;
}

posted @ 2012-08-17 01:43 hoshelly 閱讀(301) | 評論 (0)編輯 收藏

假設有N個人決定選出一個領導人,方法如下:所有人排成一個圓圈,按順序數數,每隔第M個人出局,此時他兩邊的人靠攏重新形成圓圈。問題是找出哪一個人將會是最后剩下的那個人。我們希望打印出所有人的出局順序和最后選出的領導人是哪一位。

這個問題稱為約瑟夫問題,可以利用鏈表解決。

代碼如下:

  //約瑟夫問題
  
  #include<stdio.h>
  #include<stdlib.h>
  typedef struct node *link;
  struct node { int item; link next; }; //定義結點
  int main()
  {
     int i,N,M;
     printf("Input N and M: "); //N表示共有N個人,M表示每隔第M個人要出局
     scanf("%d%d",&N,&M);
     link t = (link)malloc(sizeof(node)); //新建結點t
     link x=t; 
     t->item = 1; t->next=t; //創建一個代表1號的單個節點的循環鏈表
     for(i=2;i<=N;i++)
     {
         x=(x->next= (link)malloc(sizeof(node)));//將2~N號按序插到之前創建的單個節點的循環鏈表中
         x->item=i; x->next=t;
     }
 
     while(x!= x->next) //如果不是最后一個節點,因為是循環鏈表,所以x!=x->next
     {
         for(i=1;i<M;i++) //則順著鏈表向前遍歷,數出M-1個元素
             x=x->next;
         printf("%d ",x->next->item);
         x->next = x->next->next; //刪除第M個元素
         N--; //節點數減1
     }
     printf("\n%d\n",x->item); //最后打印出最后一個節點
     return 0;
 }

posted @ 2012-08-17 00:14 hoshelly 閱讀(1075) | 評論 (0)編輯 收藏

編寫程序,對于N個隨機產生的單位正方形中的點,統計可以被長度小于d的直線連結的點對數。

程序如下:

typedef structfloat x; float y; } point; //定義點的數據類型
float distance(point,point); //兩點之間距離函數
float distance(point a,point b)

   float dx= a.x - b.x, dy= a.y - b.y;
   return sqrt(dx*dx + dy*dy);
}
//以上為頭文件 Point.h 的內容



#include<stdio.h> 
#include<stdlib.h>
#include<math.h>
#include "Point.h"
float randFloat()
{  return 1.0*rand()/RAND_MAX; } //產生隨機數的函數
int main()
{
    float d,N;
    int i,j,cnt=0;
    scanf("%f%f",&d,&N); //d為要求兩點之間距離小于的長度,N為測試的點 
    point *a = (point *)malloc(sizeof(point)*N); //動態生成數據類型為point的數組a
    for(i=0;i<N;i++)
{
a[i].x = randFloat(); a[i].y = randFloat(); 
}
    for(i=0;i<N;i++)
        for(j=i+1;j<N;j++)
            if(distance(a[i],a[j])<d) //如果兩點之間的距離小于d,那么cnt加1
                     cnt++;
    printf("%d edges shorter than %f\n",cnt,d); //輸出有多少條邊的長度小于d
    return 0;
}

posted @ 2012-08-14 21:39 hoshelly 閱讀(332) | 評論 (0)編輯 收藏


//模擬拋硬幣的實驗

#include<stdio.h>
#include<stdlib.h>
int heads()   //返回0或非0值
{
    return rand() <RAND_MAX/2;
}

int main()
{
    int i,j,cnt;
    int N,M;
    scanf("%d%d",&N,&M); //拋一枚硬幣N=32次,如此做M=1000次這樣的實驗
    int *f=(int *)malloc((N+1)*sizeof(int));
    for(j=1;j<=N;j++) //初始化數組全部為0值
        f[j]=0;
    for(i=1;i<M;i++,f[cnt]++)  //開始拋硬幣,f[cnt]記錄第cnt次拋硬幣出現正面的次數
        for(cnt=1,j=1;j<=N;j++) //開始第一輪共32次的拋硬幣實驗
            if(heads())    cnt++; //如果出現正面,即heads()返回值為1,則對應著f[cnt]++,同時cnt++,此處利用數組索引統計正面出現次數,負面數組值始終為0
            
    for(j=1;j<=N;j++)
    {
        printf("%2d ",j);
        for(i=0;i<f[j];i+=10) printf("*"); //正面每出現十次打印一個星號
        printf("\n");
    }
    return 0;
}

posted @ 2012-08-14 10:37 hoshelly 閱讀(858) | 評論 (0)編輯 收藏

// From < C Programming FAQs > 
找出所有小于10000的素數,算法原理請自行google 埃拉托色尼篩法

程序代碼:

#define N 10000
#include<stdio.h>
int main()
{
    int i,j,a[N];
    for(i=2;i<N;i++) a[i]=1; //將數組中的值全部設為1
    for(i=2;i<N;i++)
        if(a[i])
            for(j=i;i*j<N;j++)   a[i*j]=0; //將索引為2,3,5,的倍數的數組元素設為0,因為這些數不是素數
    for(i=2;i<N;i++)
        if(a[i]) printf("4%d\n",i); //遍歷打印出找到的素數
    printf("\n");
    return 0;
}

posted @ 2012-08-13 22:17 hoshelly 閱讀(595) | 評論 (0)編輯 收藏

輸入10個學生的成績,編寫一程序對學生的成績按從高到低輸出,要求用鏈表實現。

#include<stdio.h>
#include<stdlib.h>
struct Stu
{
    int score;
    struct Stu *next;
};
typedef struct Stu Node;
int main()
{
    int i;
    Node *head,*p,*q;
    head=(Node*)malloc(sizeof(Node)); //創建頭結點
    if(head == NULL)
    {
        printf("Memory is not enough!");
        return 0;
    }
    head->next=NULL;
    for(i=0;i<10;i++)
    {
        p=(Node*)malloc(sizeof(Node)); //創建一個新結點p
        if(p == NULL)
        {
            printf("no enough memory!");
            return 0;
        }
        printf("Input the %dth student's score: ",i+1);
        scanf("%d",&p->score); //輸入成績
        q=head;
        while(q->next != NULL) //遍歷鏈表
        {
            if(q->next->score < p->score) //如果發現鏈表中的某個成績比當前輸入成績小,就跳出循環,在其前面插入當前輸入成績
                break;
            q=q->next; //繼續遍歷直到遍歷的成績比當前輸入的成績小
        }
        p->next=q->next; //這是當前成績插入到鏈表中比其小的成績前面的代碼
        q->next=p;

    }
    p=head->next;
    while(p !=NULL)  
    {
        printf("%d ",p->score);
        p=p->next;
    }

p=head;
while(p->next !=NULL)
{
    q=p->next;
    p->next=q->next;
    free(q);
}
free(head);

return 0;
}

posted @ 2012-08-12 22:23 hoshelly 閱讀(2046) | 評論 (0)編輯 收藏

編寫一個函數totsubstrnum(char *str, char *substr) ,它的功能是:統計子字符串substr在字符串str中出現的次數。

思想:len2為子串的長度,設置變量 i =0, 利用strncmp函數將str+i 開始的len2個字符與子串substr進行比較,如果相等,則count加1,此時 i 加 len2,如果不等,則 i 加1,繼續尋找。

代碼測試通過:

#include<stdio.h>
#include<string.h>
int totsubstrnum(char *str, char *substr);
int main()
{
    char str[80],substr[80];
    printf("Input string: ");
    gets(str);
    printf("Input substring: ");
    gets(substr);
    printf("count = %d\n",totsubstrnum(str,substr));

    return 0;
}

int totsubstrnum(char *str, char *substr)
{
    int i=0,count=0,len1,len2;
    len1=strlen(str);
    len2=strlen(substr);
    while(i <= len1-len2)
    {
        if(strncmp(str+i,substr,len2) == 0)
        {
            count++;
            i +=len2;
        }
        else
            i++;
    }
    return (count);
}

posted @ 2012-08-12 16:05 hoshelly 閱讀(1665) | 評論 (0)編輯 收藏

編寫一函數strlshif(char *s, int n),其功能是把字符串s中的所有字符左移n個位置,字符串中的前n個字符移到最后。

代碼測試通過:


#include<stdio.h>
#include<string.h>
void strlshif(char *s, int n);
void main()
{
    char str[]="0123456789";
    strlshif(str,3);
    printf("%s\n",str);
}

void strlshif(char *s, int n)
{
    int i,len;
    char ch;
    len=strlen(s);
    for(i=0;i<n;i++)
    {
        ch=s[0];
        strncpy(s,s+1,len-1);
        s[len-1]=ch;
    }
}

那么若是不用strncpy函數功能,如何使指定的字符串左移n位?
代碼測試通過,如下:

#include<stdio.h>
#include<string.h>
int main()
{
    char str[]="0123456789";
    char sstr[80]={0}; //使用一數組儲存移動后的字符串
    char *p;
    int c,j;
    static int i,n;
    p=&str[0];
    printf("input the number: \n");
    scanf("%d",&n); //輸入要左移的前n個字符,即將這n個字符移動到最后面
    c=n;
    while( c-- && p++ ); //找到沒有移動過的剩下的全部字符,把它們儲存在數組sstr 中

        for(i=0;i<strlen(str)-n;i++)
        {
            sstr[i]= *p;
            p++;
        }
        p=&str[0];  //指針指向第一個字符
        for(j=i;j<strlen(str);j++) //將要移動的字符一個一個地“接”到數組sstr后面
        {
            sstr[j]= *p;
            p++;
        }
        sstr[j]='\0'; //最后字符串結尾用'\0'
        printf("%s",sstr);  
        return 0;
}



        

posted @ 2012-08-12 14:14 hoshelly 閱讀(950) | 評論 (0)編輯 收藏

// s 是字符串 startloc 是開始取的位置   len表示取得子串長度
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
void substr(char *s, int startloc,int len)
{
    if((startloc < 0) || (startloc >= strlen(s)) || (len<0))
    {
        printf("input error!");
        exit(0);
    }
    int i,c=0;
    char sstr[80];
    while(*s !='\0')
    {
        if(c!=startloc)
        {
            ++c;
            s++;
        }
        else
        {
            for(i=0;i<len;i++)
            {
                sstr[i]= *s;
                s++;
            }
            sstr[i]='\0';
            break;
        }
    }
    printf("%s",sstr);
}

int main()
{
    char str[80];
    int s,l;
    printf("Input string: ");
    gets(str);
    printf("Start Location: ");
    scanf("%d",&s);
    printf("Substring length: ");
    scanf("%d",&l);
    substr(str,s,l);
    return 0;
}

    

posted @ 2012-08-12 11:45 hoshelly 閱讀(250) | 評論 (0)編輯 收藏

類似C語言中的strcat()函數,編程實現mystrcat( char *str, char * destr)的功能并測試 。


代碼測試通過:

#include<stdio.h>
void mystrcat( char *str,char *destr)
{
    while(*str !='\0')
        str++;
    while(*destr !='\0')
    {
        *str = *destr;
        str++;
        destr++;
    }

    *str = '\0';
}

int main()
{
    char str[30],destr[30];
    printf("input string and substring: ");
    scanf("%s%s",str,destr);
    mystrcat(str,destr);
    printf("%s",str);
    return 0;
}

posted @ 2012-08-12 10:16 hoshelly 閱讀(357) | 評論 (0)編輯 收藏

僅列出標題
共12頁: First 2 3 4 5 6 7 8 9 10 Last 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            玖玖精品视频| 欧美国产视频在线观看| 国产精品久久久久久五月尺| 99re6这里只有精品| 亚洲精品乱码视频| 欧美日韩国产亚洲一区| 性欧美超级视频| 羞羞视频在线观看欧美| 精品999日本| 亚洲人体大胆视频| 国产精品久久久久9999高清| 欧美在线观看视频一区二区| 欧美在线一二三| 亚洲精品久久视频| 亚洲一区国产一区| 一区精品在线| 夜夜爽99久久国产综合精品女不卡| 国产精品s色| 另类天堂av| 欧美日韩国产限制| 久久精品国产综合| 欧美激情亚洲激情| 欧美在线资源| 欧美激情aaaa| 久久久久久亚洲精品中文字幕| 欧美中文字幕| 亚洲天堂男人| 久久亚洲视频| 小黄鸭精品密入口导航| 麻豆乱码国产一区二区三区| 亚洲欧美区自拍先锋| 快播亚洲色图| 久久se精品一区二区| 欧美精品七区| 久久人人97超碰人人澡爱香蕉| 欧美精品日本| 欧美va亚洲va日韩∨a综合色| 欧美日韩亚洲视频一区| 美女爽到呻吟久久久久| 国产精品免费aⅴ片在线观看| 欧美国产极速在线| 国产日产精品一区二区三区四区的观看方式 | 中文无字幕一区二区三区| 欧美在线看片| 亚洲欧美日韩国产综合精品二区| 久久久视频精品| 欧美在线观看一区二区| 欧美日韩国产限制| 亚洲高清激情| 亚洲成人在线| 久久精品首页| 久久国产加勒比精品无码| 欧美日韩在线影院| 亚洲国产精品一区| 亚洲国产三级| 久久久欧美精品| 久久男人资源视频| 国产一区二区三区在线免费观看 | 久久精品99无色码中文字幕| 亚洲线精品一区二区三区八戒| 欧美成人免费一级人片100| 嫩草国产精品入口| 一区在线影院| 美国成人直播| 亚洲电影免费观看高清完整版| 尤物在线精品| 免费亚洲一区| 亚洲精品久久| 一区二区三区四区国产精品| 欧美日韩精品久久久| 亚洲激情自拍| 亚洲一区二区毛片| 国产欧美精品久久| 欧美在线视频一区二区三区| 久久天天躁狠狠躁夜夜av| 国产欧美一区二区精品忘忧草 | 国产精品99久久久久久有的能看 | 国产欧美日韩免费| 欧美一区二区在线免费观看| 久久久亚洲影院你懂的| 一区一区视频| 欧美激情一区二区三区在线视频| 最新亚洲一区| 性色av一区二区三区在线观看 | 欧美日韩一区二区三| 在线亚洲欧美专区二区| 久久国产黑丝| 亚洲国产精品久久久久秋霞不卡| 欧美成人免费在线观看| 日韩小视频在线观看| 午夜电影亚洲| 亚洲国产精品v| 欧美三级中文字幕在线观看| 亚洲自拍偷拍网址| 欧美激情1区2区3区| 亚洲少妇诱惑| 国产综合色在线| 欧美日韩国产一区| 久久av资源网| 亚洲精品少妇| 久久久久久穴| 亚洲制服欧美中文字幕中文字幕| 国产嫩草一区二区三区在线观看| 久久精品亚洲精品| 一本色道久久综合狠狠躁篇怎么玩 | 久久综合亚洲社区| 亚洲伦理自拍| 国产一区二区三区无遮挡| 欧美激情综合| 久久久九九九九| 一区二区三区四区五区精品| 免费不卡亚洲欧美| 欧美亚洲视频一区二区| 亚洲美女色禁图| 韩日欧美一区二区| 国产精品高潮呻吟| 欧美a级一区二区| 欧美制服第一页| 亚洲影院在线观看| 亚洲美女啪啪| 亚洲国产精品成人综合色在线婷婷 | 欧美日韩一卡| 欧美成人黑人xx视频免费观看| 销魂美女一区二区三区视频在线| 亚洲激情视频网| 六月丁香综合| 久久精品一区蜜桃臀影院| 亚洲一区国产精品| 亚洲免费久久| 亚洲黄色毛片| 亚洲国产另类 国产精品国产免费| 国产精品丝袜xxxxxxx| 欧美日韩三区四区| 欧美精品一区二区视频| 久久在线免费观看| 久久久国产精品亚洲一区| 欧美亚洲日本网站| 亚洲免费影视第一页| 一区二区成人精品| 在线亚洲国产精品网站| 一本色道婷婷久久欧美| 亚洲伦理中文字幕| 一本色道久久99精品综合| 亚洲最新在线| 一区二区三区偷拍| 亚洲欧美激情视频在线观看一区二区三区| 99精品久久久| 一区二区三区日韩在线观看| 日韩亚洲欧美一区| 国产精品99久久久久久白浆小说| 一区二区激情小说| 亚洲一区二区在线免费观看| 亚洲免费在线播放| 久久精品1区| 久久影音先锋| 欧美区亚洲区| 国产精品久久77777| 国产麻豆日韩欧美久久| 国产日韩在线亚洲字幕中文| 国产一区二区高清视频| 亚洲成人资源| 一区二区三区欧美成人| 亚洲欧美日韩国产一区| 久久九九免费视频| 欧美高清视频一区二区三区在线观看 | 亚洲国产成人tv| 夜色激情一区二区| 午夜精品久久久久影视| 久久天堂精品| 亚洲精品一区二区三| 亚洲欧美日本国产有色| 久久精品亚洲一区| 欧美久久久久久蜜桃| 国产精品视频男人的天堂| 一区二区三区在线免费观看| 亚洲欧洲另类国产综合| 亚洲欧美另类中文字幕| 蜜臀久久99精品久久久久久9| 欧美国产一区在线| 亚洲一区在线免费观看| 美女精品视频一区| 国产精品草草| 亚洲黄色免费| 欧美一区二区高清在线观看| 欧美激情小视频| 亚洲永久免费精品| 欧美顶级少妇做爰| 国产香蕉久久精品综合网| 日韩一级黄色片| 久久亚洲国产精品一区二区| 亚洲免费观看| 久久天堂成人| 国产日产欧美一区| 一区二区冒白浆视频| 久久综合色播五月| 亚洲欧美日韩精品在线| 欧美日韩国产页| 91久久精品国产91久久性色| 久久久久欧美| 午夜精品福利一区二区三区av|