字符串拷贝和拼接

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <assert.h>

//1.一个数组中只有两个数字是出现一次,
//其他所有数字都出现了两次。
//找出这两个数字,编程实现。
void print(int arr[],int length){
    int i = 0;
    int j = 0;
    for (i = 0; i < length; i++){
        for (j = 0; j < length; j++){
            if (arr[i] == arr[j] && i != j){
                break;
            }
        }
        if (j == length){
            printf("%d ", arr[i]);
        }

    }
}
//
//
//2.喝汽水,1瓶汽水1元,2个空瓶可以换一瓶汽水,
//给20元,可以多少汽水。
//编程实现。

int countQiShui(int money){
    //初始买汽水的数量
    int count1 = money;
    //统计汽水的总和
    int count2 = money;
    while (count1 != 1){
        count2 += count1 / 2;
        count1 /= 2;
    }
    return count2;
}
//3.模拟实现strcpy
char * Strcpy(char *str1, char *str2){
    assert(str1);
    assert(str2);
    int i = 0;
    for (; i < strlen(str2); i++){
        str1[i] = str2[i];
    }
    str1[i] = ‘\0‘;
    return str1;
}
//4.模拟实现strcat
char * Strcat(char *str1, char *str2){
    assert(str1);
    assert(str2);
    int i = strlen(str1);
    int j = 0;
    for (; j < strlen(str2);j++, i++){
        str1[i] = str2[j];
    }
    str1[i] = ‘\0‘;
    return str1;
}

int main(){

    /*int arr[] = { 1, 1, 2, 3, 4, 4 };
    int length = 6;
    print(arr, length);*/

    /*printf("%d\n", countQiShui(10));*/

    /*char str1[] = "abcdef";
    char str2[] = "abcdefg";
    printf("%s\n", Strcpy(str1, str2));*/

    /*char str1[] = "abcdef";
    char str2[] = "abcdefg";
    printf("%s\n",Strcat(str1, str2));*/

    system("pause");
    return 0;
}

原文地址:https://www.cnblogs.com/duy666/p/10254475.html

时间: 2024-10-03 19:11:01

字符串拷贝和拼接的相关文章

字符串拷贝函数strcpy写法_转

Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->// CppReference.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" using namespace std; /* * 说明:字符串拷贝版本1 * 参数:dest目标地址,src源地址 * 返回:返回拷贝好的地址:如果出错或者有重叠,无

虚怀若谷 字符串拷贝函数strcpy写法_转

Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->// CppReference.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" using namespace std; /* * 说明:字符串拷贝版本1 * 参数:dest目标地址,src源地址 * 返回:返回拷贝好的地址:如果出错或者有重叠,无

编写实现字符串拷贝函数strcpy()完整版

有个题目编程实现字符串拷贝函数strcpy(),很多人往往很快就写出下面这个代码. void strcpy( char *strDest,char *strSrc ) { while(( *strDest++ = * strSrc++) != '\0' );//逐个赋值字符串数组中的数据,知道字符串结束 } 其实仔细看看这个实现过程并不完美,严格来说非常不严谨,我们可以完善一下. char * strcpy( char *strDest, const char *strSrc )//将源字符串加

c语言:两种方法实现字符串拷贝strcpy

实现字符串拷贝strcpy 方法一: // 字符串拷贝函数的实现 #include<stdio.h> #include<assert.h> void my_strcpy(char *dest,  char *src)//src表示source源,dest目标 { assert(dest!=NULL); assert(src); char *ret = dest; while (*dest++ = *src++) { ; } return dest; } int main() { c

Strlcpy和strlcat——一致的、安全的字符串拷贝和串接函数

概述 随着流行的缓冲区溢出攻击的增加,越来越多程序员开始使用带有大小,即有长度限制的字符串函数,如strncpy() 和strncat() .尽管这种趋势令人十分鼓舞,但通常的标准C 字符串函数并不是专为此而设计的.本文介绍另一种直观的,一致的,天生安全的字符串拷贝API . 当函数 strncpy()和 strncat()作为 strcpy()和 strcat()的安全版本来使用时,仍然存在一些安全隐患. 这两函数以不同的,非直观的方式来处理NUL 结束符和长度参数,即使有经验的程序员也会混淆

makefile规则编写&amp;C语言字符串拷贝&amp;vim介绍

makefile规则:[email protected]:目标文件$^:所有的依赖文件$<:第一个依赖文件-c:输出目标代码,不输出可执行文件-g:编译器编译的时候提供以后对程序调试的信息target:rules    gcc -o [email protected] $^install:    cp target /usr/local/binclean:    rm target    lib库查找方法:nm -o /lib/*.so | grep "函数名字" nm -o /

C++内存问题大集合(指针问题,以及字符串拷贝问题,确实挺危险的)

作者:rendao.org,版权声明,转载必须征得同意. 内存越界,变量被篡改 memset时长度参数超出了数组长度,但memset当时并不会报错,而是操作了不应该操作的内存,导致变量被无端篡改 还可能导致内存越界的函数有memset.memcpy.memmove.strcpy.strncpy.strcat.sprintf等等 临时指针问题,std::string.wstring的c_str()是个临时指针 c_str()返回值是个char*/wchar_t*指针,这个数组的数据是临时的,当有一

关注C++细节——字面值初始化字符数组及字符串拷贝注意

char carr[] = "author:CSDN-iaccepted"; 此时,carr数组中元素的个数为21,最后一个位置用来存放空字符'\0'. 所以如果写成carr[21] = "author:CSDN-iaccepted";就是错误的. int clen = strlen(carr); int size = sizeof(carr); 这时候得到的clen = 21,size= 22.这就是因为strlen统计串中字符的个数,不计算最后的空字符,但是si

字符串拷贝问题

问题:把源字符串拷贝到目的字符串,如果指定关键字,则以该关键字结束(不包括关键字本身),如果拷贝失败,则得到空串.具体要求:实现如下函数原型SafeStrcpy2KeyWord(),并在代码中调用该函数实现上述功能.该函数的实现要考虑各种可能的参数取值,以确保程序不出现崩溃. int SafeStrcpy2KeyWord(char* pDestBuffer,    //拷贝的目的地地址 char* pSourceString,    //拷贝的源地址 int nDestBufferSize,