本專欄持續輸出數據結構題目集,歡迎訂閱。
文章目錄
- 題目
- 代碼
題目
請編寫程序,將給定字符串 t 插入到另一個給定字符串 s 的第 pos 個字符的位置。
輸入格式:
輸入先后給出主串 s 和待插入的字符串 t,每個非空字符串占一行,不超過 1000 個字符,以回車結束(回車不算在字符串內)。第三行給出插入的位序 pos(注意位序從 1 開始,保證不超過 s 的長度加 1)。
輸出格式:
在一行中輸出將 t 插入 s 的第 pos 個字符的位置后的結果字符串。
如果插入后的字符串長度超過了 1000 個字符,則不要插入,而是在一行中輸出 錯誤:插入將導致字符串長度超限。,并且在第二行輸出原始主串 s。
輸入樣例:
This is a test.
simple-
11
輸出樣例:
This is a simple-test.
代碼
#include <stdio.h>
#include <string.h>#define MAX_LENGTH 1000int main() {char s[MAX_LENGTH + 1], t[MAX_LENGTH + 1];int pos;// 讀取主串 sfgets(s, MAX_LENGTH + 1, stdin);// 移除換行符if (s[strlen(s) - 1] == '\n') {s[strlen(s) - 1] = '\0';}// 讀取待插入的字符串 tfgets(t, MAX_LENGTH + 1, stdin);// 移除換行符if (t[strlen(t) - 1] == '\n') {t[strlen(t) - 1] = '\0';}// 讀取插入位置 posscanf("%d", &pos);// 計算插入后的總長度int new_length = strlen(s) + strlen(t);if (new_length > MAX_LENGTH) {printf("錯誤:插入將導致字符串長度超限。\n");printf("%s\n", s);} else {// 創建臨時數組存儲結果char result[MAX_LENGTH + 1];// 復制 s 的前半部分(到 pos-1 位置)strncpy(result, s, pos - 1);result[pos - 1] = '\0';// 追加 tstrcat(result, t);// 追加 s 的后半部分(從 pos 位置開始)strcat(result, s + pos - 1);printf("%s\n", result);}return 0;
}