求字符串长度
#include<stdio.h>
int strLength(char ch[]){
int n=0;
int i=0;
while(ch[i]!='\0'){
i++;
n++;
}
return n;
}
int main(){
char ch[100];
printf("请输入字符串:");
scanf("%s",ch);
int num=strLength(ch);
printf("字符串长度%d",num);
}
整数转换成字符串
#include<stdio.h>
char* convert(int num,char* str){
int i=0;
if(num<0){
num=-num;
str[i++]='-';
}
while(num){
str[i++]=num%10+48;
num=num/10;
}
str[i]='\0';
int j=0;
if(str[0]=='-'){
j=1;
++i;
}
for(;j<i/2;j++){
str[j] = str[j] + str[i-1-j];
str[i-1-j] = str[j] - str[i-1-j];
str[j] = str[j] - str[i-1-j];
}
}
int main(){
int num=-123456;
char string[16]={0};
convert(num, string);
printf("数字:%d 转换后的字符串为:%s\n",num,string);
return 0;
}
结构体数组应用(输入,排序,输出)
#include<stdio.h>
struct people{
int key;
int value;
}p[10];
void input(){
for(int i=0;i<10;i++){
printf("请输入编号和成绩:");
scanf("%d %d",&p[i].key,&p[i].value);
}
}
void sort(int n){
for(int i=0;i<n;i++){
for(int j=i+1;j<n;j++){
if(p[i].value<p[j].value){
int temp = p[i].value;
p[i].value=p[j].value;
p[j].value=temp;
}
}
}
// for(int i=0;i<n;i++){
// printf("请输入编号%d的成绩%d",p[i].key,p[i].value);
// }
}
void top3(){
sort(10);
for(int i=0;i<3;i++){
printf("请输入编号%d的成绩为%d",p[i].key,p[i].value);
}
}
int main(){
input();
printf("---------------\n");
// sort(10);
printf("---------------\n");
top3();
return 0;
}
整数转换成二进制
#include<stdio.h>
int main(){
int a[32];
printf("输入一个十进制数:");
int x;
scanf("%d",&x);
int i=0;
while(x!=0){
a[i]=x%2;
i++;
x=x/2;
}
for(;i>0;i--){
printf("%d",a[i-1]);
}
}
数组求100以内素数
#include<stdio.h>
int main(){
int a[100];
for(int i=1;i<100;i++){
a[i]=i+1;
}
a[0]=0;
for(int i=1;i<100;i++){
for(int j=i+1;j<100;j++){
if(a[i]!=0&&a[j!=0]){
if(a[j]%a[i]==0){
a[j]=0;//把素数全部赋值为0
}
}
}
}
for(int i=0;i<100;i++){
if(a[i]!=0){
printf("%d ",a[i]);
}
}
}
最大公约数
1.
#include<stdio.h>
int main(){
int a,b;
printf("输入两个数:");
scanf("%d %d",&a,&b);
while(a!=b){
if(a>b){
a=a-b;
}
if(a<b){
b=b-a;
}
}
printf("最大公约数为:%d",a);
return 0;
}
2.
#include<stdio.h>
int main(){
int a,b,c;
printf("输入两个数:");
scanf("%d %d",&a,&b);
if(a>b){
c=b;
}else{
c=a;
}
while(a%c!=0||b%c!=0){
c--;
}
printf("最大公约数为:%d",c);
return 0;
}
3.
#include<stdio.h>
int main()
{
int a = 0;
int b = 0;
int c = 0;
printf("输入两个数求最大公约数: ");
scanf("%d%d",&a,&b);
c = a%b;
while(c)
{
a = b;
b = c;
c = a%b;
}
printf("最大公约数为: %d\n",b);
return 0;
}