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

天之道

享受編程的樂趣。
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>
            国产精品视频九色porn| 国产视频一区在线观看| 亚洲人成人99网站| 欧美激情一区二区在线| 欧美精品久久久久久久| 一区二区免费在线播放| 一区二区精品在线观看| 国产精品久久久久久久久久久久| 亚洲影视中文字幕| 亚洲直播在线一区| 国内偷自视频区视频综合| 欧美成人69| 欧美日韩亚洲高清一区二区| 午夜久久黄色| 久久久国产一区二区| 激情综合在线| 99re6这里只有精品| 国产欧美一区在线| 欧美本精品男人aⅴ天堂| 欧美激情a∨在线视频播放| 亚洲一区二区在| 久久成人精品视频| 亚洲伦伦在线| 亚洲一区二区三区在线看| 红桃视频国产一区| 9久re热视频在线精品| 国产日韩欧美a| 亚洲国产aⅴ天堂久久| 欧美婷婷六月丁香综合色| 久久精品视频在线看| 欧美成人69| 欧美一区二区三区在线看| 欧美成人激情视频| 久久成人av少妇免费| 欧美顶级艳妇交换群宴| 久久99伊人| 欧美日韩国产bt| 久久久亚洲国产美女国产盗摄| 欧美高清视频在线| 久久精品国产亚洲高清剧情介绍| 欧美精选在线| 美女任你摸久久| 国产精品免费aⅴ片在线观看| 欧美成人综合一区| 国产美女扒开尿口久久久| 亚洲精品乱码久久久久久黑人| 国产综合久久久久影院| 亚洲一区视频| 亚洲自拍偷拍一区| 欧美激情一区二区三区不卡| 久久久久久久999精品视频| 国产精品盗摄一区二区三区| 亚洲电影第1页| 亚洲国产经典视频| 性娇小13――14欧美| 午夜在线观看欧美| 国产精品久久久久久超碰 | 韩国免费一区| 亚洲影院色无极综合| 亚洲性夜色噜噜噜7777| 欧美国产日产韩国视频| 亚洲成色www8888| 红桃av永久久久| 久久成人精品无人区| 久久久久女教师免费一区| 国产乱码精品一区二区三区av | 欧美在线观看一区| 国产精品欧美经典| 一区二区黄色| 欧美一级大片在线观看| 欧美日韩综合在线| 一区二区三区高清在线| 亚洲欧美另类中文字幕| 欧美视频二区| 亚洲欧美第一页| 久久国产夜色精品鲁鲁99| 国产欧美日韩一级| 欧美一区午夜精品| 麻豆精品视频在线观看| 亚洲国产成人午夜在线一区 | 亚欧成人在线| 久久久久成人精品免费播放动漫| 国产亚洲一级| 久久一区二区三区av| 亚洲国产mv| 亚洲欧美变态国产另类| 国产视频不卡| 久久亚洲私人国产精品va| 亚洲第一毛片| 亚洲欧美春色| 好吊色欧美一区二区三区四区 | 亚洲第一天堂无码专区| 亚洲人成在线观看| 欧美吻胸吃奶大尺度电影| 亚洲一区二区在| 久久久国产精彩视频美女艺术照福利| 一区福利视频| 欧美三级精品| 久久电影一区| 99视频一区二区| 久久久久久久久久久久久女国产乱 | 免费欧美网站| 国产精品99久久久久久www| 久久久久九九视频| 99在线视频精品| 国产视频久久久久久久| 欧美激情一区二区三区四区| 午夜精品一区二区三区在线视 | 亚洲图片欧洲图片av| 久久久xxx| 国产精品99久久99久久久二8 | 欧美aaa级| 欧美一区二区在线视频| 亚洲美女在线国产| 免费日韩成人| 久久久久国产免费免费| 亚洲少妇诱惑| 亚洲激情啪啪| 韩国精品一区二区三区| 欧美午夜寂寞影院| 欧美承认网站| 久久精品99国产精品日本| 一区二区高清在线观看| 亚洲电影观看| 久热国产精品| 久久精品国产亚洲精品| 亚洲香蕉在线观看| 亚洲精品在线观| 亚洲高清在线播放| 黄色一区二区三区四区| 国产噜噜噜噜噜久久久久久久久 | 久久久国产午夜精品| 亚洲私人影吧| 一区二区三区欧美| 亚洲日本在线视频观看| 欧美激情aⅴ一区二区三区| 久久伊伊香蕉| 久久久久国色av免费观看性色| 亚洲免费在线观看| 亚洲视频大全| 亚洲一区二区精品在线观看| 亚洲免费大片| 9国产精品视频| 一区二区三区精密机械公司| 亚洲美女性视频| 亚洲精选中文字幕| 日韩一级在线| 亚洲午夜国产一区99re久久| 99re8这里有精品热视频免费 | 国产精品永久免费| 国产精品美女久久| 国产精品免费区二区三区观看| 国产精品第13页| 国产精品日韩欧美一区二区| 国产精品日日摸夜夜摸av| 国产精品区二区三区日本| 国产精品性做久久久久久| 国产三区精品| 亚洲电影中文字幕| 91久久精品国产91久久| 一本色道久久综合精品竹菊| 一区二区三区精品在线| 欧美一区二区三区免费在线看| 篠田优中文在线播放第一区| 久久久99久久精品女同性| 美女久久一区| 亚洲免费观看高清完整版在线观看熊 | 小黄鸭精品aⅴ导航网站入口| 久久精品国产综合精品| 欧美**人妖| a4yy欧美一区二区三区| 亚洲免费伊人电影在线观看av| 欧美中文字幕视频在线观看| 久久亚洲图片| 国产精品户外野外| 狠狠色伊人亚洲综合成人| 亚洲另类在线一区| 亚洲欧美日韩精品一区二区| 久久久人成影片一区二区三区| 免费永久网站黄欧美| 日韩视频一区二区三区| 亚洲欧美中文日韩在线| 欧美国产亚洲精品久久久8v| 国产精品一区二区在线| 亚洲精品社区| 久久久久成人精品| 亚洲毛片网站| 久久中文字幕一区| 国产精品亚洲片夜色在线| 亚洲精品一区久久久久久| 欧美在线视频免费观看| 亚洲精品久久久久中文字幕欢迎你 | 亚洲午夜女主播在线直播| 乱中年女人伦av一区二区| 99re6热在线精品视频播放速度 | 亚洲网站在线观看| 欧美不卡视频一区| 国产真实乱偷精品视频免| 亚洲影音先锋| 亚洲精品看片|