线性表的题目

题目一
快速找到未知长度的单链表的中间节点
普通方法
由于单链表不知道长度,必须遍历完整个单链表才知道单恋表的长度,然后根据一般的长度去找中间结点,这是普通方法。
问的是快速找到,当然要用快速的方法啦
有一个很巧妙的方法,快慢指针
快指针每次走2个结点,慢指针每次走1个结点,当快指针走完链表,慢指针刚好走到中间,这就是快慢指针的核心思想。

int GetMidNode(node* L)  //寻找链表中间值
    {
        int a;
        node *search,*mid;
        mid = search = L;
        while(search->next != NULL)
        {
            if(search->next->next != NULL)
                {
                    search = search->next->next;
                    mid= mid->next;
                }
            else
                {
                    search = search->next;
                }
        }
        a = mid->data;
        return a;
    }

题目二
约瑟夫环
问题描述:N个人围成一圈,从第一个人开始报数,报到m的人出圈,剩下的人继续从1开始报数,报到m的人出圈;如此往复,直到所有人出圈。(模拟此过程,输出出圈的人的序号)

循环单链表解法:

#include<stdio.h>   

#include <stdlib.h>  



typedef struct node//节点存放一个数据和指向下一个节点的指针  

{  

    int data;  

    struct node* pnext;  

} Node;  



Node *link_create(int n)//创建n个节点的循环链表  

{  

    //先创建第1个节点  

    Node *p,*q,*head;  

    int i ;  

    p = (Node *)malloc(sizeof(Node));  

    head = p;  

    p->data = 1;  



    for(i = 2;i<=n;i++)//再创建剩余节点  

    {  

        q = (Node *)malloc(sizeof(Node));  

        q->data = i;  

        p->pnext = q;  

        p = q;  

    }  

    p->pnext = head;//最后一个节点指向头部,形成循环链表  

    return head;  

}  



void link_process(Node *head,int k,int m)//从编号为k(1<=k<=n)的人开始报数,数到m的那个人出列;  

{  

  int i;  

    Node *p = head,*tmp1;  

    while(p->data != k)//p指向的节点data为k 

    {

        tmp1 = p;

        p = p->pnext;  

    }



    while(p->pnext != p)  

    {  

        for(i=1;i<m;i++)  

        {  

            tmp1 = p;  

            p = p->pnext;  

        }  

        printf("%d ",p->data);  

        tmp1->pnext= p->pnext;  

        free(p);  

        p = tmp1->pnext;  



    }  

    printf("%d ",p->data);  

    free(p);  

}  



int main()  

{  

    Node *head = link_create(5);      

    link_process(head,3,1);  

    system("pause");  

    return 0;  

}  

C++数列推导实现(数学推导式)

推导求解

现在考虑一种泛化情形:总共有 n 个人,数到 k 的人被杀掉,其中 n >= k。幸存者的位置为 pn

显而易见,初始位置为 k 的人将会第一个被杀掉。此时,经过重新排序之后,问题变成了 n-1 个人的情形。幸存者的位置为 pn-1 。如果能够找到从 pn-1 到 pn 的递推关系,那么问题就解决了。

重新排序之后,每个人的位置发生了下面这些变化:

  • 1 -> n-k+1
  • 2 -> n-k+2
  • ...
  • k-1 -> n-1
  • k 被杀死
  • k+1 -> 1
  • ...
  • pn -> pn-1
  • ...
  • n-1 -> n-k+1
  • n -> n-k

很容易我们能得到这样一个关系式:pn = (pn-1 + k) % n 。再加上刚才讨论的特例,只有一个人的情况时,p1 = 1 。递推式就已经很明显了。

当然上文只讨论了 n>=k 的情形,实际上对于 n<k 的情形,刚才所得到的递推式依然适用,我们就不展开讨论了。

#include <iostream>
#include <list>
using std::cout;
using std::endl;
using std::cin;
using std::list;

int main()
{
    int total  = 0;
    cout << "Please input total number of people : ";
    cin >> total;

    int number = 0;
    cout << "Please input selected number : ";
    cin >> number;

/* If number = 3
 * f(1) = 0
 * f(2) = 1 = (f(1) + 3) % 2
 * f(3) = 1 = (f(2) + 3) % 3
 * f(4) = 0 = (f(3) + 3) % 4
 * f(5) = 3 = (f(4) + 3) % 5
 * ...
 * f(n) = x = (f(n-1) + 3) % n
 * */

    int last = 0; // f(1) = 0
    for(int i = 2; i <= total; ++i)
    {
        last = (last + number) % i;
    }
    cout << "The last one is : " << last + 1 << endl;

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

推荐阅读更多精彩内容