算法入门笔记------------Day2
1.开灯问题
有n盏灯,编号为1~n,第一个人把所有灯打开,第二个按下所有编号为2的倍数的开关(这些灯都被关掉),第三个人按下所有编号为3的倍数的开关,依次类推,一共有k个人,问最后有哪些灯开着?输入n和k,输出开着的灯的编号?
#include<stdio.h>
#include<string.h>
int a[1000]; //我们用数组来保存灯的状态
int main(void)
{
int n,k,i,j;
int first=1;//最后的格式输出
memset(a,0,sizeof(a)); //把灯先设置为0,表示灯是关的
//然后模拟所有的关灯和开灯的操作
scanf("%d%d",&n,&k); //输入人数和灯数
for(i=1;i<=k;i++)
{
for(j=1;j<=n;j++)
{
if(j%i==0) a[j]=!a[j]; //如果满足条件,按动开关
}
}
for(j=1;j<=n;j++)
{
if(a[j]==1)
{
if(first) first=0;
else printf(" ");
printf("%d",j);
}
}
printf("\n");
return 0;
}
2.蛇形填数
在n*n的方阵填入1,2,...,n*n,要求填成蛇形,例如n=4
10 11 12 1
9 16 13 2
8 15 14 3
7 6 5 4
#include<stdio.h>
#include<string.h>
#define MAX 10
int a[MAX][MAX];
int main(void)
{
int x,y,n,tot;
scanf("%d",&n); `
memset(a,0,sizeof(a));
tot=a[x=0][y=n-1]=1; //确定起点
while(tot<n*n) //判断有没有越界,注意下一个是不是0,还有如果x+1<n为假,则就不计算后面的,因为&&短路预算
{
while(x+1<n && !a[x+1][y]) a[++x][y]=++tot;
while(y-1>=0 && !a[x][y-1]) a[x][--y]=++tot;
while(x-1>=0 && !a[x-1][y]) a[--x][y]=++tot;
while(y+1<n && !a[x][y+1]) a[x][++y]=++tot;
}
for(x=0;x<n;x++)
{
for(y=0;y<n;y++)
printf("%3d",a[x][y]);
printf("\n");
}
return 0;
}
3.竖式问题
找出所有形如abc*de的算式,使得在完整的竖式中,所有数字都属于一个特定的数字集合,输入数字集合,输出所有竖式.
#include<stdio.h>
#include<string.h>
int main(void)
{
char s[20],buf[100];
int abc,de,x,y,z,ok;
int num=0;
scanf("%s",s);
for(abc=111;abc<=999;abc++)
{
for(de=11;de<=99;de++)
{
x=abc*(de%10);y=abc*(de/10);z=abc*de;
sprintf(buf,"%d%d%d%d%d",abc,de,x,y,z); //写入字符串buf中
ok=1;
for(int i=0;i<strlen(buf);i++) //比较buf和s中的字符是不是都有
{
if(strchr(s,buf[i])==NULL) ok=0;
}
if(ok) //成功的标志
{
printf("<%d>\n",++num); //计数
printf("%5d\nX%4d\n-----\n%5d\n%4d\n-----\n%5d\n\n",abc,de,x,y,z);
}
}
}
printf("The number of solutions =%d\n",num);
return 0;
}
4.最长回文子串
输入一个字符串,求出其中最长的回文子串.
//分析,首先不适用使用scanf来输入字符串,因为碰到空格或者TAB就会停下
//于是我们可以使用fgets
//先找最大回文子串的长度
#include<stdio.h>
#include<string.h>
#include<ctype.h>
#define MAX 5000
char buf[MAX],s[MAX];
int main(void)
{
int n,m=0,max=0;
int i,j,k;
fgets(buf,sizeof(buf),stdin); //输入字符串
n=strlen(buf); //求字符串长度
for(i=0;i<n;i++)
if(isalpha(buf[i])) s[m++]=toupper(buf[i]); //全部变成大写,方便判别
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
{
int ok=1;
for(k=i;k<=j;k++) //s[k]的对称位置是s[i+j-k]
{
if(s[k]!=s[i+j-k]) ok=0;
}
if(ok&&j-i+1>max) max=j-i+1;
}
}
printf("max=%d\n",max);
return 0;
} #include<stdio.h>
#include<string.h>
#include<ctype.h>
#define MAX 5000
char buf[MAX],s[MAX];
int p[MAX];
int main(void)
{
int n,m=0,max=0;
int x,y,i,j;
fgets(buf,sizeof(buf),stdin);
n=strlen(buf);
for(i=0;i<n;i++)
{
if(isalpha(buf[i]))
{
p[m]=i;
s[m++]=toupper(buf[i]);
}
}
for(i=0;i<m;i++)
{
for(j=0;i-j>=0&&i+j<m;j++) //从内部向外分开,奇数情况,aba
{
if(s[i-j]!=s[i+j]) break;
if(j*2+1>max) {
max=j*2+1;
x=p[i-j];
y=p[i+j];
}
}
for(j=0;i-j>=0&&i+j+1<m;i++) //从内部向外分开,偶数情况,考虑aabb
{
if(s[i-j]!=s[i+j+1]) break;
if(j*2+2>max) {
max=j*2+2;
x=p[i-j];
y=p[i+j+1];
}
}
}
for(i=x;i<=y;i++)
printf("%c",buf[i]);
printf("\n");
return 0;
}
习题
分数统计
任务1 分数为不吵为100的非负整数
#include<stdio.h>
#include<string.h>
int main(void)
{
int num[110];
int x;
int ans;
int max=0;
memset(num,0,sizeof(num));
while(scanf("%d",&x)==1)
{
num[x]++;
}
for(int i=0;i<=100;i++)
{
if(num[i]>=max)
{
max=num[i];
ans=i;
}
}
for(int i=0;i<101;i++)
{
if(num[i]==max)
printf("%d ",i);
}
printf("\n");
return 0;
}
任务2 输入为不超过100的非负实数
//习题3.1,分数统计(stat)
#define LOCAL
#include<stdio.h>
#include<string.h>
#include<math.h>
#ifndef MAX
#define MAX 10000+1
#endif
int a[MAX];
int main()
{
//从本地读取文件(重定向),不用每次都进行数据输入
#ifdef LOCAL
freopen("data.txt","r",stdin);
#endif
memset(a,0,sizeof(a));
double degree;
while(scanf("%lf",°ree) == 1){
//直接double强制转化为int会出现问题,如4.9999999999,应为5,但会是4.9
//使用floor进行四舍五入可以解决这个问题
double m = degree * 100;
int n = floor(m+0.5);
a[n] += 1;
} int i,max = a[0];
int tmp[MAX];
memset(tmp,0,sizeof(tmp));
for(i=1; i <= MAX; i++){
if(a[i] > max){
max = a[i];
}
}
int j = 0;
for(i = 0; i < MAX; i++){
if(a[i] == max){
tmp[j] = i;
j++;
}
}
for (i = 0; i < j; ++i)
{
double temp = tmp[i]*0.01;
printf("%.2f\n",temp);
}
return 0;
}
单词的平均长度
#include<stdio.h>
int main(void)
{
char ch;
int num=0,words=0;
int inword=0;
while((ch=getchar())!=EOF)
{
if(isalpha(ch)) num++;
if(!isspace(ch)&&!inword)
{
inword=1;
words++;
}
if(isspace(ch)&&inword)
inword=0;
}
printf("The averge word is %.2f\n",(double)num/words);
return 0;
}
乘积的末3位
输入若干个整数(可以是正数、负数或者零),输出它们的乘积的末3位。这些整数中会混入一些由大写字母组成的字符串,你的程序应该忽略它们。提示:试试看,在执行scanf("%d")时输入一个字符串会怎样?
输入:AB123CC BB123123321321 DDD22 888888888888888888888888888ZZ -411B
输出:968
输入:AA-11BBB D2CCC
输出:-22
假定末3位是指,不足3位就输出数字本身,如果是负数则包括负号,比如结果是-12,则输出-12;结果是11,则输出11,结果是0,则输出0;
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <stdlib.h>
#define N 100000
#define M 5000
#define L 5
char input[N];
char str[M];
char tmp[L];
char rev[L]; int main(void)
{
int i, len, k;
int flag = 1;
int product = 1;
char *p = NULL; fgets(input, sizeof (input), stdin);
p = input;
while (sscanf(p, "%s", str) == 1) {
len = k = 0;
for (i = strlen(str)-1; i != -1; i--) {
if (len != 3 && 1 == isdigit(str[i]))
tmp[len++] = str[i];
if (str[i] == '-') {
flag = -flag;
break;
}
}
tmp[len] = '\0';
while (len > 0)
rev[k++] = tmp[--len];
rev[k] = '\0';
product *= atoi(rev);
product %= 1000;
p += strlen(str)+1;
while (*p == ' ') p++;/* 滤空 */
}
printf("%d\n", product < 100 ? product*flag : product);
return 0;
}
计算器
编程程序读入一行恰好包括一个+或-或*的表达式,输出它的值。运算符保证是二元运算符,且两个运算数均不超过100的非负整数。运算数和运算符可以紧挨也可以有一个或多个空格、TAB隔开。行首尾均可以有空格。提示:选择合适的输入方法可以将问题简化。
#include <stdio.h>
#define N 1000
char str[N];
int main(void)
{
char *p = NULL;
int op1, op2; fgets(str, sizeof(str), stdin);//it will contains '\n'; for (p = str; *p != '\n'; p++) {
if (*p == '+' || *p == '-' || *p == '*')
break;
}
if (*p != '\n'){
switch(*p) {
case '+':
sscanf(str, "%d + %d", &op1, &op2);
printf("%d\n", op1+op2);
break;
case '-':
sscanf(str, "%d - %d", &op1, &op2);
printf("%d\n", op1-op2);
break;
case '*':
sscanf(str, "%d * %d", &op1, &op2);
printf("%d\n", op1*op2);
break;
}
}
return 0;
}
输入一个n*n字符矩阵,把它左旋90度后输出
#include <stdio.h>
#define N 100 char a[N][N];
int main(void)
{
int n;
int i, j; scanf("%d", &n); for (i = 0; i != n; i++) {
for (j = 0; j != n; j++)
scanf("%s", &a[i][j]);
} for (j = n-1; j != -1; j--) {
for (i = 0; i != n; i++)
printf("%c ", a[i][j]);
printf("\n");
} return 0;
}
进制转换
#include <stdio.h>
voidtrans(int n, int b)
{
if (n >= b)
trans(n/b, b);
printf("%d", n%b);
}
void trans(int n, int b);
int main(void)
{
int b, n; scanf("%d %d", &b, &n);
trans(n, b);
printf("\n");
return 0;
} //非递归
#include <stdio.h>
#define N 100
int a[N];
int main(void)
{
int b, n;
int k = 0;
int i; scanf("%d %d", &b, &n);
while (n >= b) {
a[k++] = n%b;
n /= b;
}
a[k++] = n%b;
for (i = k-1; i != -1; i--)
printf("%d", a[i]);
printf("\n");
return 0;
} //输出基数b( 2 <= b <= 10)和正整数n(b进制),输出n的十进制表示
#include <stdio.h>
#include <string.h>
#define N 100
char str[N];
int main(void)
{
int n, i, k, tmp;
int res = 0; scanf("%d %s", &n, str);
for (i = strlen(str)-1; i != -1; i--) {
tmp = str[i]-'0';
k = strlen(str)-1-i;
while(k--)
tmp *= n;
res += tmp;
}
printf("%d\n", res); return 0;
}
算法入门笔记------------Day2的更多相关文章
- 算法入门笔记------------Day4
1.WERTYU 输入一个错位后敲出的字符串,输出打字员本来想打出的字 #include<stdio.h> char *s="`1234567890-=QWERTYUIOP[]\ ...
- 算法入门笔记------------Day3
主要是复习前面的基本内容,以及函数的概念 组合数 #include<stdio.h> int f(int n) { int m=1; for(int i=1;i<=n;i++) m* ...
- 算法入门笔记------------Day1
1.C语言使用%d显示float值,不会把float值转换为近似的int值,而是显示垃圾值,使用%f显示int值,也不会把该int值转换为浮点值 2.三位数反转:输入一个三位数,分离它的百位,十位和个 ...
- Android NDK JNI 入门笔记-day04-NDK实现Hash算法
* Android NDK JNI 入门笔记目录 * 开头 前面的学习,我们已经掌握了 NDK 开发的必备知识. 下一步就要多实践,通过创造问题并解决问题,来增加熟练度,提升经验. 日常开发中,经常会 ...
- 「Android 开发」入门笔记
「Android 开发」入门笔记(界面编程篇) ------每日摘要------ DAY-1: 学习笔记: Android应用结构分析 界面编程与视图(View)组件 布局管理器 问题整理: Andr ...
- React.js入门笔记
# React.js入门笔记 核心提示 这是本人学习react.js的第一篇入门笔记,估计也会是该系列涵盖内容最多的笔记,主要内容来自英文官方文档的快速上手部分和阮一峰博客教程.当然,还有我自己尝试的 ...
- redis入门笔记(1)
redis入门笔记(1) 1. Redis 简介 •Redis是一款开源的.高性能的键-值存储(key-value store).它常被称作是一款数据结构服务器(data structure serv ...
- C++ 快速入门笔记:进阶编程
C++入门笔记:高级编程 文件和流 打开文件 void open (const char *filename, ios::openmode mode); ios::app 追加模式.所有写入都追加到文 ...
- golang微服务框架go-micro 入门笔记2.2 micro工具之微应用利器micro web
micro web micro 功能非常强大,本文将详细阐述micro web 命令行的功能 阅读本文前你可能需要进行如下知识储备 golang分布式微服务框架go-micro 入门笔记1:搭建go- ...
随机推荐
- 发现 git忽略没用
git rm --cached GuoJiWeb/Properties/PublishProfiles/Profile1.pubxml
- java io流之BufferReader&BufferedWriter
BufferedReader 由Reader类扩展而来,提供通用的缓冲方式文本读取,而且提供了很实用的readLine,读取一个文本行,从字符输入流中读取文本,缓冲各个字符,从而提供字符.数组和行的高 ...
- POJ 1015 Jury Compromise 2个月后重做,其实这是背包题目
http://poj.org/problem?id=1015 题目大意:在遥远的国家佛罗布尼亚,嫌犯是否有罪,须由陪审团决定.陪审团是由法官从公众中挑选的.先随机挑选n个人作为陪审团的候选人,然后再从 ...
- iOS 实现app文件共享
解决方式如下,在应用程序的Info.plist文件中添加UIFileSharingEnabled键,并将键值设置为YES.将您希望共享的文件放在应用程序的Documents目录.一旦设备插入到用户计算 ...
- Synchronized和Static Synchronized区别
通过分析这两个用法的分析,我们可以理解Java中锁的概念. 一个是实例锁(锁在某一个实例对象上,如果该类是单例,那么该锁也具有全局锁的概念), 一个是全局锁(该锁针对的是类,无论实例多少个对象,那么线 ...
- Java Calendar 注意事项
Java JDK 提供了java.util.Calendar来处理日期和时间.Calendar是一个抽象类,是所有日历的模板,因此我们可以继承Calendar来实现其他的历法(比如阴历). Java提 ...
- Oracle RMAN 恢复控制文件到指定的路径
Oracle 数据库通过RMAN恢复控制文件到指定的路径 --------------------------------------------------------- 先查询备份集信息,再指定备 ...
- protobuf初体验
概念介绍 Protocol buffers 是google公司的与语言无关.与平台无关的.可扩张的为序列化话结构数据,就像xml一样,办事更加的小巧.快速.简单.Protocol buffers 目前 ...
- 让Asp.net mvc WebAPI 支持OData协议进行分页查询操作
这是我在用Asp.net mvc WebAPI 支持 OData协议 做分页查询服务时的 个人拙笔. 代码已经开发到oschina上.有兴趣的朋友可以看看,欢迎大家指出不足之处. 看过了园子里的几篇关 ...
- css3新特性@rgba
1.rgba也经常在实际应用中使用,它主要是在原来rgb的基础上添加了一透明度.但是他又和opacity又有一些差别,主要体现在对子元素的透明度的影响上. 例如:使用opacity和backgroun ...