遞歸 段錯誤 習題

段錯誤

  1. 遞歸里面算階乘 f(10000000)沒有輸出,使用gdb 顯示 SIGSEGV--段錯誤
  2. 編譯后產生的可執行文件里面保存著什么?
    1. UNIX/Linux 用 ELF
    2. DOS下用COFF
    3. Windows用PE(COFF擴充而得)
  3. 段(segmentation)
    1. 二進制文件內的區域。
    2. 可用size程序得到可執行文件中的各個段的大小
    3. Text Segment--正文段--儲存指令
    4. Data Segment--數據段--儲存已初始化的變量
    5. BSS Segment--BSS段--未賦值的全局變量
    1. 棧不儲存在可執行文件內,而是在運行時創建
    2. 調用棧所在的段成為Stack Segment
    3. 和其他段一樣,不能越界訪問,否則會stack overflow
    4. 調用棧保存函數的調用關系和局部變量
    5. 棧空間的大小
      1. linux 通過ulimit修改 ulimit -a顯示當前棧的大小, ulimit -s 32768 把棧大小指定為32MB
      2. windows 用gcc指定執行文件的棧大小,-Wl,--stack=<byte count>
    6. 局部變量也是放在堆棧段中,棧溢出不一定是因為遞歸調用太多次,可能是局部變量太大。因此建議“把較大的數組放在main函數外。

競賽題目

  1. 劊子手游戲
    1. 看輸入字符和給定字符關系
    2. 使用全局變量可便于維護內容,可以免去過多的參數傳遞。
    3. 猜過的字母再猜一次算錯:將猜過的字母從答案內“刪去”(改成不可能滿足為答案的條件的數據)
  2. 救濟金發放
    1. 一圈官員,兩個官員逆時,順時針數k, m個數,停下,被選中的離開隊伍(可能是同一個人)
    2. #include<stdio.h>
      #define maxn 25
      int n,k,m,a[maxn];
      //逆時針走t步,步長為d 返回新位置
      int go(int p,int d,int t)
      {while(t--){do{    //前面減去1??? p=(p+d+n-1)%n+1;        //注意這里經過的數字是步數加一! 因此會有最后的+1; 
              }while(a[p]==0);}return p;} int main(){while(scanf("%d%d%d",&n,&k,&m)){for(int i=1;i<=n;i++) a[i]=i;int left=n;int p1=n,p2=1;while(left){p1=go(p1,1,k);p2=go(p2,-1,m);printf("%3d",p1);left--;if(p2!=p1){printf("%3d",p2);left--;}a[p1]=a[p2]=0;if(left)printf(",");}printf("\n");}return 0;}
  3. 信息解碼
    1. 01字符串,長度會逐漸增加,且不存在全1的串。 編寫一個解碼程序,輸入一個編碼頭,則序列的每個串對應一個字符。再編碼文本。每個小結前三個數字表示編碼長度,每小節以全1結束,編碼以000結束。

轉載于:https://www.cnblogs.com/xuwanwei/p/10753888.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/279620.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/279620.shtml
英文地址,請注明出處:http://en.pswp.cn/news/279620.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

你知道你常用的dos和linux命令嗎?

功能 Linux MS-DOS 進入到該目錄 cd cd 列舉文件 ls dir 創建目錄 mkdir mkdir 清除屏幕 clear cls 復制文件 cp copy 移動文件 mv move 刪除文件 rm del 查看文件 less more 文件重命名 mv ren 比較文件內容 diff fc 查看當前路徑 pwd chd…

steam串流到手機_如何從手機將Steam游戲下載到PC

steam串流到手機Steam allows you to remotely install games from your smartphone, just like you can with a PlayStation 4 or Xbox One. You can download games to your gaming PC from anywhere, ensuring those big downloads are complete and the game is ready to p…

編寫安裝配置ftp-samba服務腳本

本腳本實例的要求如下&#xff1a; 1、公司有公共共享目錄public,所有員工均可讀寫&#xff0c;但不允許刪除其他員工的文件;不能匿名登錄 2、每部門均有共享目錄&#xff0c;部門經理可讀寫&#xff0c;部門員工可讀&#xff1b; 非本部門員工不能訪問&#xff08;caiwu、rens…

利用java實現excel轉pdf文件

在有些需求當中我們需要抓取字段并且填充到excel表格里面&#xff0c;最后將excel表格轉換成pdf格式進行輸出&#xff0c;我第一次接觸這個需求時&#xff0c;碰到幾個比較棘手的問題&#xff0c;現在一一列出并且提供解決方案。 1&#xff1a;excel轉pdf出現亂碼&#xff1a; …

Jmeter HTTP請求后響應數據顯示亂碼解決方法

Jmeter請求后結果樹里無論是text還是html響應數據顯示亂碼&#xff0c;這是因為jmeter 編碼格式配置文件默認不開啟導致的&#xff0c;解決方法如下&#xff1a; 1&#xff09;進入jmeter-***\bin目錄下&#xff0c;找到jmeter.properties文件&#xff0c;以文本文件形式打開 2…

禁用windows10更新_如何在Windows 10中禁用投影

禁用windows10更新The drop shadows on applications in the Windows 10 preview are really big and suspiciously similar to the ones in OS X, and if they aren’t your speed, you can easily remove them. We actually think they look good, but since somebody out th…

如何訪問 Service?- 每天5分鐘玩轉 Docker 容器技術(99)

前面我們已經學習了如何部署 service&#xff0c;也驗證了 swarm 的 failover 特性。不過截止到現在&#xff0c;有一個重要問題還沒有涉及&#xff1a;如何訪問 service&#xff1f;這就是本節要討論的問題。 為了便于分析&#xff0c;我們重新部署 web_server。 ① docker se…

sqlyog下載

sqlyog下載&#xff08;附注冊碼&#xff09;&#xff1a;http://www.onlinedown.net/soft/24926.htm轉載于:https://www.cnblogs.com/shujuxiong/p/9474496.html

Linux配置手冊(二)配置DHCP服務器

1.檢查是否安裝DHCP服務器軟件 2.掛在RHEL5系統光盤 3.安裝DHCP服務軟件 4.將模板配置文件復制并覆蓋現在的配置文件 5.配置修改dhcpd.conf文件 配置信息 默認租約時間 default-lease-time 最大租約時間 max-lease-time 局域網內所有主機的域名 option domain-name 客戶機所使用…

什么是Google Play保護以及如何確保Android安全?

Android is open, flexible, and all about choice. Unfortunately, that flexibility comes more potential security issues. The good news is that Google has a system in place named Play Protect that helps keep Android secure. Android開放&#xff0c;靈活且具有多…

如何使計算機為您讀取文檔

Since the beginning of the computer age, people have always enjoyed making computers talk to them. These days, that functionality is built right into Windows and you can easily use it to have your PC read documents to you. 自計算機時代開始以來&#xff0c;人…

面試中常問的List去重問題,你都答對了嗎?

2019獨角獸企業重金招聘Python工程師標準>>> 面試中經常被問到的list如何去重&#xff0c;用來考察你對list數據結構&#xff0c;以及相關方法的掌握&#xff0c;體現你的java基礎學的是否牢固。 我們大家都知道&#xff0c;set集合的特點就是沒有重復的元素。如果集…

Coolite Toolkit學習筆記五:常用控件Menu和MenuPanel

Coolite Toolkit里的Menu控件和其他的.NET Web控件不一樣&#xff0c;如果只是設計好了Menu或是通過程序初始化菜單項&#xff0c;菜單是不會呈現在界面上的&#xff0c;因為Coolite Toolkit規定Menu控件需要一個容器來做依托&#xff0c;而這個讓Menu依托的控件就是MenuPanel&…

剛接觸git,提交文件時,遇到no changes added to commit

第一次用git 在提交&#xff08;git commit -m add 文件名&#xff09;的時候&#xff0c;遇到了一個no changes added to commit&#xff0c;大體意思是沒有將改變的東西提交成功&#xff0c;查了很多博客&#xff0c;才解決這個問題&#xff0c;然后自己也做一下筆記&#…

CSS中!important的使用

本篇文章使用最新的IE10以及firefox與chrome測試&#xff08;截止2013年5月27日22:23:22&#xff09;http://www.cnblogs.com/yudy/archive/2013/05/27/3102825.html CSS的原理&#xff1a; 我們知道&#xff0c;CSS寫在不同的地方有不同的優先級&#xff0c; .css文件中的定義…

windows命令提示符_如何個性化Windows命令提示符

windows命令提示符Command line interfaces can be downright boring and always seem to miss out on the fresh coats of paint liberally applied to the rest of Windows. Here’s how to add a splash of color to Command Prompt and make it unique. 命令行界面可能非常…

android-api28轉換到api19-不能編譯

安裝出現錯誤- rootponkan:/ # pm install /mnt/usb/sda1/app-debug.apkpkg: /mnt/usb/sda1/app-debug.apk Failure [INSTALL_FAILED_OLDER_SDK]查看系統和api版本 rootponkan:/ # getprop ro.build.version.release 5.1.1 rootponkan:/ # getprop ro.build.version.sdk 22將ap…

Java多線程編程 — 鎖優化

2019獨角獸企業重金招聘Python工程師標準>>> 閱讀目錄 一、盡量不要鎖住方法 二、縮小同步代碼塊&#xff0c;只鎖數據 三、鎖中盡量不要再包含鎖 四、將鎖私有化&#xff0c;在內部管理鎖 五、進行適當的鎖分解 正文 并發環境下進行編程時&#xff0c;需要使用鎖機…

Android Ap 開發 設計模式第六篇:原型模式

Prototype Pattern 名稱由來 不是利用類來產生實例對象&#xff0c;而是從一個對象實例產生出另一個新的對象實例 &#xff0c;根據被視為原型的對象實例 &#xff0c;建立起的另一個新的對象實例就稱為原型模式&#xff08;Ptototype Pattern&#xff09;。 需求場景 種類過多…

netty實現客戶端服務端心跳重連

前言&#xff1a; 公司的加密機調度系統一直使用的是http請求調度的方式去調度&#xff0c;但是會出現網絡故障導致某個客戶端或者服務端斷線的情況&#xff0c;導致很多請求信息以及回執信息丟失的情況&#xff0c;接著我們拋棄了http的方式&#xff0c;改為Tcp的方式去建立客…