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

天之道

享受編程的樂趣。
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>
            亚洲一区日韩| 老牛影视一区二区三区| 免费在线成人| 夜夜嗨av一区二区三区网站四季av| 日韩视频在线观看免费| 国产精品视频自拍| 蜜臀a∨国产成人精品| 欧美伦理视频网站| 久久成人国产精品| 欧美成人小视频| 亚洲欧美日韩综合国产aⅴ| 久久久久久久久久久久久久一区| 夜久久久久久| 久久久久久综合| 亚洲视频久久| 久久偷窥视频| 午夜日韩在线| 欧美日韩国产亚洲一区| 久久免费午夜影院| 国产精品啊v在线| 亚洲电影自拍| 国产亚洲a∨片在线观看| 亚洲高清免费在线| 国内精品久久久久影院薰衣草| 亚洲欧洲一区二区三区在线观看| 国产欧美日韩中文字幕在线| 亚洲三级网站| 1024国产精品| 欧美一区2区三区4区公司二百 | 亚洲精品美女91| 国产视频一区二区三区在线观看| 亚洲精品日本| 亚洲经典在线看| 久久福利毛片| 欧美一区二区精品久久911| 欧美日韩在线一区二区| 欧美激情小视频| 一区二区三区在线观看国产| 亚洲免费影院| 午夜精品在线| 国产精品乱看| 国产精品99久久久久久www| 99视频有精品| 欧美日本一区二区三区| 亚洲国产精品第一区二区| 亚洲国产日韩欧美综合久久| 理论片一区二区在线| 久久综合伊人77777尤物| 国产亚洲欧美中文| 欧美一区二区视频在线观看| 欧美亚洲自偷自偷| 国产精品视频久久| 亚洲在线观看免费| 欧美在线亚洲在线| 国产美女诱惑一区二区| 亚洲欧美日韩国产综合| 久久精品国产久精国产爱| 国产欧美在线看| 午夜久久资源| 久久久久久综合| 一色屋精品视频免费看| 蜜臀va亚洲va欧美va天堂| 亚洲国产日韩欧美在线图片| 日韩一区二区精品| 欧美日韩妖精视频| 亚洲一区制服诱惑| 久久久噜噜噜久久人人看| 狠狠综合久久| 免费一级欧美片在线播放| 亚洲精品国产日韩| 亚洲一区二区精品| 国产精品一区在线观看| 久久精品亚洲乱码伦伦中文| 欧美国产精品久久| 中国成人黄色视屏| 国产视频一区欧美| 美日韩精品视频| 一区二区久久久久| 久久精品人人做人人爽| 亚洲国产精品t66y| 欧美日韩理论| 欧美在线播放一区| 欧美黄色aa电影| 在线视频免费在线观看一区二区| 国产精品露脸自拍| 蜜桃久久av一区| 亚洲午夜免费福利视频| 看片网站欧美日韩| 中文欧美在线视频| 国产午夜精品美女毛片视频| 免费试看一区| 亚洲女同精品视频| 亚洲电影观看| 久久aⅴ国产欧美74aaa| 亚洲激情偷拍| 久久久久久久欧美精品| 亚洲国产毛片完整版| 欧美在线播放一区二区| 亚洲精品在线视频| 国产一区二区毛片| 欧美午夜视频一区二区| 久久久噜噜噜久久| 中文精品视频| 亚洲大胆av| 欧美一区2区三区4区公司二百| 亚洲精品网站在线播放gif| 麻豆国产精品777777在线 | 亚洲小视频在线| 亚洲黄色成人网| 亚洲福利视频网| 一区二区激情| 亚洲国产精品传媒在线观看| 欧美成人精品福利| 午夜精品一区二区三区电影天堂| 午夜性色一区二区三区免费视频| 久久综合成人精品亚洲另类欧美| 久久激情五月丁香伊人| 久久久久久91香蕉国产| 美女91精品| 欧美成人网在线| 久久免费的精品国产v∧| 免费一级欧美片在线观看| 欧美精品日韩综合在线| 国产精品xnxxcom| 国产色产综合产在线视频| 欧美一区二区三区在线观看| 久久精品官网| 亚洲精品久久久久久久久久久久久| 亚洲精选91| 欧美日韩免费| 亚洲午夜一区二区三区| 亚洲一级二级在线| 午夜日韩av| 国产精品久久久久av免费| 国产一区二区三区黄| 久久久精品午夜少妇| 欧美一区三区二区在线观看| 久久午夜精品一区二区| 在线观看av不卡| 亚洲少妇自拍| 亚洲午夜性刺激影院| 快射av在线播放一区| 亚洲国产成人不卡| 亚洲一区二区三区乱码aⅴ蜜桃女| 宅男精品视频| 国产欧美日韩一级| 久久久亚洲一区| 久热爱精品视频线路一| 亚洲二区在线观看| 欧美激情影院| 欧美www视频| 亚洲私拍自拍| 久久久蜜桃精品| 老牛影视一区二区三区| 免费看av成人| 亚洲精品一区二区三| 在线综合亚洲欧美在线视频| 亚洲欧美激情一区二区| 久久久精品五月天| 欧美1区免费| 欧美性一二三区| 国产综合网站| 亚洲欧洲日产国码二区| 在线一区二区视频| 久久国产福利| 女人天堂亚洲aⅴ在线观看| 亚洲电影专区| 中国av一区| 久久av免费一区| 欧美va日韩va| 国产精品影音先锋| 亚洲高清毛片| 亚洲午夜精品| 久久精品一区| 欧美国产第二页| 99在线观看免费视频精品观看| 这里只有精品视频在线| 欧美在线视频免费观看| 欧美国产三区| 国产欧美精品在线播放| 亚洲国产日韩在线| 亚洲欧美日韩国产综合在线| 麻豆freexxxx性91精品| 99国产精品| 久久久九九九九| 欧美视频精品在线观看| 伊人久久综合97精品| av成人天堂| 久久三级视频| 在线一区二区三区四区五区| 久久在精品线影院精品国产| 亚洲经典自拍| 午夜视频在线观看一区二区三区| 久热re这里精品视频在线6| 国产精品福利网站| 极品日韩久久| 亚洲一区二区精品在线| 男人的天堂亚洲在线| 一本色道久久综合狠狠躁篇怎么玩| 性18欧美另类|